yii CDbCriteria详细说明

来源:互联网 发布:网球比赛直播软件 编辑:程序博客网 时间:2024/05/22 08:17

yii数据模型搜索方法:

$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 &nbsp;


//这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition,
//即如果第二个参数是数组就会调用addInCondition &nbsp;


$criteria->compare('id', 1); &nbsp; &nbsp;
/** &nbsp;* 传递参数 */ &nbsp;


$criteria->addCondition("id = :id"); &nbsp;
$criteria->params[':id']=1; &nbsp;


//order&nbsp;
$criteria->order = 'xxx DESC,XXX ASC' ;//排序条件 &nbsp;


//group
$criteria->group = 'group 条件'; &nbsp;
$criteria->having = 'having 条件 ';&nbsp;


//limit
$criteria->limit = 10; &nbsp; &nbsp;//取1条数据,如果小于0,则不作处理 &nbsp;
$criteria->offset = 1; &nbsp; //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10 &nbsp;

 

 

 

 

 

public function search()
    {
        // Warning: Please modify the following code to remove attributes that
        // should not be searched.

        $criteria=new CDbCriteria;

        $criteria->compare('id';$this->id);
        $criteria->compare('title';$this->title,true);                //支持模糊查找
        $criteria->compare('content';$this->content,true);            //支持模糊查找
        $criteria->compare('type';$this->type);
        $criteria->compare('user';$this->user,true);                //支持模糊查找
        $criteria->compare('status';$this->status);
        $criteria->compare('create_data';$this->create_data,true);    //支持模糊查找

        return new CActiveDataProvider($this, array(
            'criteria'=>$criteria,
            'pagination'=>array(
                'pageSize'=>50,
            ),
        ));
    }
    
定义比较运算:
        
    $criteria->compare('create_time';'<='.$this->endtime),//创建早间小于等于指定时间  

定义要查找的字段:
    
    //查找的结果    
    $criteria->select = 'id,title,content,author,status,createtime';
    //也可以以下一种方式定义
    $criteria->select = array('id';'title';'content';'author';'status';'createtime');
    
定义填加查找条件:

    //定义条件    
    $criteria->select =  'status=1';
    //添加匹配
    $criteria->compare('title';$this->title,true);
    //添加条件 $condition可以是数组,也可以是字符串,and可以省略
    $criteria->addCondition($condition,'and');
    //添加IN条件 $column为字段名
    $criteria->addInCondition(string $column, array $values, string $operator='AND');
    //添加notin条件
    $criteria->addNotInCondition(string $column, array $values, string $operator='AND');
    //添加like条件
    $criteria->addSearchCondition(string $column, string $keyword);
    //添加Between条件
    $criteria->addBetweenCondition(string $column, string $valueStart, string $valueEnd, string $operator='AND');
    
JOIN连表查询:

    $criteria->join = 'LEFT JOIN users ON users.id=authorID';
    
order查询结果排序:

    $criteria->order = 'createtime DESC';
    
group结果分组:

    $criteria->group =  'projectID, teamID';
    
having筛选分组结果分组数量:
    
    $criteria->having =  'SUM(revenue)<50000';




转自:http://www.kuitao8.com/20140529/2561.shtml


0 0
原创粉丝点击