zoukankan      html  css  js  c++  java
  • Yii CDbCriteria

    Yii的Active Recorder包装了很多。

    特别是把SQL中 把where,order,limit,IN/not IN,like等常用短句都包含进CDbCriteria这个类中去,这样整个代码会比较规范,一目了然。CDbCriteria
    代表一个标准的查询, 如条件,order by和limit.
    它是一个数据封装对象,相当于SQL语句的各部分的载体

       $criteria =newCDbCriteria; 


       $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);//between1 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 offset1,或者代表了。limit 1,10  
       $criteria->order = 'xxx DESC,XXX ASC' ;//排序条件 
       $criteria->group = 'group 条件'; 
       $criteria->having = 'having 条件 '; 
       $criteria->distinct = FALSE;//是否唯一查询

    更多:

    http://www.cnblogs.com/likwo/archive/2011/09/01/2162017.html

  • 相关阅读:
    CodeForces 706C Hard problem
    CodeForces 706A Beru-taxi
    CodeForces 706B Interesting drink
    CodeForces 706E Working routine
    CodeForces 706D Vasiliy's Multiset
    CodeForces 703B Mishka and trip
    CodeForces 703C Chris and Road
    POJ 1835 宇航员
    HDU 4907 Task schedule
    HDU 4911 Inversion
  • 原文地址:https://www.cnblogs.com/youxin/p/3898164.html
Copyright © 2011-2022 走看看