php yii orm,Yii中的sql查询的位置(或任何支持ORM的框架)?
對(duì)于使用MVC體系結(jié)構(gòu)的項(xiàng)目,這是更多的編碼風(fēng)格問題。
我正在使用Yii框架開展一個(gè)項(xiàng)目。 每個(gè)數(shù)據(jù)庫表都有它自己的模型類,可以讓我充分利用Yii的活動(dòng)記錄。 涼。
但是現(xiàn)在我需要用一個(gè)復(fù)雜的邏輯和大量的表進(jìn)行SQL查詢。 最好和最快捷的方法是編寫一個(gè)原始SQL,并將其放入一些getSomeComplexLogicData方法中。
問題是,我在哪里放這個(gè)方法? 將它放在一個(gè)我稱之為控制器的地方是很好的做法(它不太可能會(huì)在其他地方重新使用),還是應(yīng)該將它放在最適合的某個(gè)Model類中?
Yii的“模型”不需要擴(kuò)展CActiveRecord 。
您可以創(chuàng)建一個(gè)簡(jiǎn)單的域?qū)ο?#xff0c;該對(duì)象包含代碼中某些結(jié)構(gòu)的業(yè)務(wù)邏輯,并為該結(jié)構(gòu)提供單獨(dú)的映射器,其中包含復(fù)雜的SQL查詢。
你應(yīng)該盡量避免在一個(gè)班級(jí)中集中所有,因?yàn)槟阕罱K會(huì)違反SRP,這是活動(dòng)記錄模式通常被認(rèn)為是有害的主要原因之一(當(dāng)然有一些例外)。 它傾向于將機(jī)器人域邏輯和存儲(chǔ)邏輯整合到一個(gè)類中,因此很難進(jìn)行測(cè)試和維護(hù)。
如果您使用的是正確的MVC或MVC設(shè)計(jì)模式,則不會(huì)有“模型”。 模型應(yīng)該是一個(gè)層。 不是課堂或?qū)ο蟆?你不應(yīng)該有任何域控制器業(yè)務(wù)邏輯暴露。
1)您可以將此方法放入組件/ Controller.php中,以便將此方法用于您的每個(gè)應(yīng)用程序控制器。
2)最好的方法是制作一個(gè)你自己的組件。 你可以從控制器,模型,視圖中調(diào)用你的組件。Yii::app()->yourcomponentname->methodname
學(xué)習(xí)如何制作組件的鏈接:http://www.yiiframework.com/wiki/187/how-to-write-a-simple-application-component/
鏈接地址: http://www.djcxy.com/p/60843.html
總結(jié)
以上是生活随笔為你收集整理的php yii orm,Yii中的sql查询的位置(或任何支持ORM的框架)?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php把excel变成数组,PHP ex
- 下一篇: mysql创建表为什么第二次,mysql