Heim  >  Artikel  >  Backend-Entwicklung  >  Zusammenfassung gängiger Methodenbeispiele in Yii CDBCriteria

Zusammenfassung gängiger Methodenbeispiele in Yii CDBCriteria

高洛峰
高洛峰Original
2017-01-21 11:50:011158Durchsuche

Die Beispiele in diesem Artikel beschreiben gängige Methoden von Yii CDBCriteria. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Hinweis: $c = new CDbCriteria(); ist eine Möglichkeit, ActiveRecord zu schreiben, was ActiveRecord flexibler macht, anstelle von DAO (PDO) und Query Builder im Handbuch.

Ein kleiner Kommentar: Ich finde, dass dieser Teil des Handbuchs durchschnittlich ist.

Linkadresse: http://www.yiiframework.com/doc/api/1.1/CDbCriteria

Dies sind einige Hinweise und die allgemeine Verwendung von Yii CDbCriteria:

一, eine SQL-Assembly-Situation

PHP-Code:

$criteria = new CDbCriteria;
//函数方式
$criteria->addCondition("id=1"); //查询条件,即where id = 1
$criteria->addInCondition('id', array(1,2,3,4,5)); //代表where id IN (1,23,,4,5,);
$criteria->addNotInCondition('id', array(1,2,3,4,5));//与上面正好相法,是NOT IN
$criteria->addCondition('id=1','OR');//这是OR条件,多个条件的时候,该条件是OR而非AND
$criteria->addSearchCondition('name', '分类');//搜索条件,其实代表了。。where name like '%分类%'
$criteria->addBetweenCondition('id', 1, 4);//between 1 and 4
$criteria->compare('id', 1); //这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition,
//即如果第二个参数是数组就会调用addInCondition
$criteria->addCondition("id = :id");
$criteria->params[':id']=1;
//属性方式
$criteria->select = 'id,parentid,name'; //代表了要查询的字段,默认select='*';
$criteria->join = 'xxx'; //连接表
$criteria->with = 'xxx'; //调用relations
$criteria->limit = 10; //取1条数据,如果小于0,则不作处理
$criteria->offset = 1; //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10
$criteria->order = 'xxx DESC,XXX ASC' ;//排序条件
$criteria->group = 'group 条件';
$criteria->having = 'having 条件 ';
$criteria->distinct = FALSE; //是否唯一查询

Beispiel:

PHP-Code:

$criteria = new CDbCriteria();
$criteria->select = 'table_name,model_id,sum(amount) total';
$criteria->group = 'table_name,model_id';
$criteria->addCondition("$nIdcId=4");//也可以$criteria->condition = "$nIdcId=4";
$aResult = accessory_info::model()->findAll($criteria);
$c = new CDbCriteria();
$c->select = 't.id, t.created_at, t.outsource_id, t.user_id, t.operate, t.content';
$c->join = 'LEFT JOIN outsource ON outsource.id=t.outsource_id';
$c->condition = 'outsource.idc_id IN(' . implode(',', $idc_ids) . ')';
if($last_log_id) {
$c->condition .= " AND t.id > $last_log_id";
}
$c->limit = 20;
$c->order = 't.id DESC';
$logs = OutsourceProcessLog::model()->findAll($c);

Anmerkungen:

1 Der Unterschied zur DAO-Methode besteht darin, dass jedes Element im DAO-Methodenarray immer noch ein Array ist. Bei der CDbCriteria-Methode sind die Elemente im Array Objekte.
2. Auch wenn diese Funktion sehr leistungsfähig ist, gibt es dennoch einige Anforderungen, die nicht erfüllt werden können, und es sind immer noch SQL-Anweisungen erforderlich. Wählen Sie beispielsweise den avg(num)-Betrag aus **** aus.
3. Drucken Sie die Ergebnisse nach dem Ausführen aus, und Sie können mehr darüber erfahren, wie Yii diesen

PHP-Code implementiert:

//可见
$c = new CDbCriteria();
$c->join = "JOIN idc_user on t.id=idc_user.user_id";
$c->condition = "idc_user.idc_id=$idc_id";
//运行后
object(CDbCriteria)#98 (12) { ["select"]=> string(1) "*" ["distinct"]=> bool(false) ["condition"]=> string(17) "idc_user.idc_id=6" ["params"]=> array(0) { } ["limit"]=> int(-1) ["offset"]=> int(-1) ["order"]=> string(0) "" ["group"]=> string(0) "" ["join"]=> string(38) "JOIN idc_user on t.id=idc_user.user_id" ["having"]=> string(0) "" ["with"]=> NULL ["alias"]=> NULL }
//User::model()->with('Idcs')->findAll($c)

2. Der Fall von mergeWith

PHP-Code:

//在ActiveRecord中,增加条件限制
$this->getDbCriteria()->mergeWith(array(
'condition'=>"idc_id IN ($ids)",
));

Ich hoffe, dass dieser Artikel für jedermann beim PHP-Programmdesign basierend auf dem Yii-Framework hilfreich sein wird.

Weitere Beispiele für gängige Yii CDBCriteria-Methoden und zusammenfassende Artikel finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn