zoukankan      html  css  js  c++  java
  • Yii CDbCriteria类中方法

    $criteria = new CDbCriteria;   
    //select  
    $criteria->select = '*';//默认*  
    $criteria->select = 'id,name';//指定的字段  
    $criteria->select = 't.*,t.id,t.name';//连接查询时,第一个表as t,所以用t.*  
    $criteria->distinct = FALSE; //是否唯一查询   
      
      
    //join  
    $criteria->join = 'left join table2 t2 on(t.id=t2.tid)'; //连接表    
    $criteria->with = 'xxx'; //调用relations    
      
      
    //where 查询数字字段  
    $criteria->addCondition("id=1"); //查询条件,即where id = 1    
    $criteria->addBetweenCondition('id', 1, 4);//between 1 and 4       
    $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  
      
      
    //where 查询字符串字段  
    $criteria->addSearchCondition('name', '分类');//搜索条件,其实代表了。。where name like '%分类%'   
       
    //where 查询日期字段  
    $criteria->addCondition("create_time>'2012-11-29 00:00:00'");  
    $criteria->addCondition("create_time<'2012-11-30 00:00:00'");  
      
      
    //where and or  
    $criteria->addCondition('id=1','OR');//这是OR条件,多个条件的时候,该条件是OR而非AND    
      
      
    //这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition,  
    //即如果第二个参数是数组就会调用addInCondition    
      
      
    $criteria->compare('id', 1);      
    /**  * 传递参数 */    
      
      
    $criteria->addCondition("id = :id");    
    $criteria->params[':id']=1;    
      
      
    //order   
    $criteria->order = 'xxx DESC,XXX ASC' ;//排序条件    
      
      
    //group  
    $criteria->group = 'group 条件';    
    $criteria->having = 'having 条件 ';   
      
      
    //limit  
    $criteria->limit = 10;    //取1条数据,如果小于0,则不作处理    
    $criteria->offset = 1;   //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10 
    Yii的Active Recorder包装了很多。
    
    特别是把SQL中 把where,order,limit,IN/not IN,like等常用短句都包含进CDbCriteria这个类中去,这样整个代码会比较规范,一目了然。
    
       $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;//是否唯一查询
    CDbCriteria 公共属性:
    
    CDbCriteria.alias    string    类型 表别名.
    CDbCriteria.condition    string    类型 查询条件
    CDbCriteria.distinct    boolean    类型 是否只选择不相同的数据行
    CDbCriteria.group    string    类型 如何进行分组查询结果
    CDbCriteria.having    string    类型 作为GROUP-BY子句的条件
    CDbCriteria.index    string    类型 作为查询结果数组的索引
    CDbCriteria.join    string  类型 如何加入其它的表
    CDbCriteria.limit    integer 类型 要返回最大记录值
    CDbCriteria.offset    integer 类型 要返回从0开始的偏移量
    CDbCriteria.order    string    类型 如何对结果进行排序
    CDbCriteria.paramCount  integer 类型 绑定域名的全局记数器
    CDbCriteria.param    array    类型 以参数占位符为索引的查询参数列表
    CDbCriteria.scopes    mixed    类型 定义多个查询条件,进行组合
    CDbCriteria.select    mixed    类型 被选中的列
    CDbCriteria.with    mixed    类型 相关联的查询标准
    
    
    CDbCriteria.addBetweenCondition()  添加一个between条件到条件属性中
    CDbCriteria.addColumnCondition() 附加一个相匹配的列值的条件
    CDbCriteria.addCondition() 附加一个条件到已存在的条件中
  • 相关阅读:
    PHP Laravel Install and Quickstart
    PHP Composer
    PHP学习 Cookie和Session
    PHP学习 Object Oriented 面向对象 OO
    PHP学习 例外和错误处理
    PHP学习 文件访问和写入
    PHP学习 函数 function
    PHP学习 流程控制和数组
    修改docker镜像地址为阿里云
    通信对象 System.ServiceModel.Channels.ServiceChannel 无法用于通信,因为其处于“出错”状态
  • 原文地址:https://www.cnblogs.com/rainblack/p/5611027.html
Copyright © 2011-2022 走看看