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() 附加一个条件到已存在的条件中
时间: 2024-10-29 00:34:06

Yii CDbCriteria类中方法的相关文章

C#反射调用程序集类中方法

建立类 class OperatorClass { /// <summary> /// 加法 /// </summary> /// <param name="x"></param> /// <param name="y"></param> /// <returns></returns> /// public static int Add(int x, int y) { r

struts_2_Action类中方法的动态调用

(一)直接调用方法(不推荐使用) 1)Action类: private String savePath; public String getSavePath() { return savePath; } public void setSavePath(String savePath) { this.savePath = savePath; } public String other() { savePath = "other"; return "success";

android开发中关于继承activity类中方法的调用

android开发中关于继承activity类中的函数,不能在其他类中调用其方法. MainActivity.java package com.example.testmain; import android.app.Activity; import android.os.Bundle; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState)

关于一个类中方法的调用

大家都知道:对象是对客观事物的抽象,类是对对象的抽象,对象是类的实例. 在类中来调用方法.不过调用方法也有种种的情况.(如下几种情况) 情况一:同一个类中的两个方法相互调用 1.如果两个方法都是普通的方法,也就是非静态的方法的话,是可以直接调用的.例 ( public void a(){ system.out.println(“内容”): b(): } public void b(){ system.out.println(“内容2”): } ) 2.如果两个方法都是静态的方法,那么也是可以直接

关于类中方法的调用

同一个类中的两个方法相互调用: 1.两种方法都是普通的方法:可以直接用方法名调用 2.两种方法都是静态方法:可以直接用方法名调用 3.一种方法为静态,一种方法为普通: ①在静态方法中调用普通方法:不可以直接使用,需要创建对象 ②在普通方法中调用静态方法:可以直接用方法名调用

关于一个类中方法调用

大家都知道:对象是对客观事物的抽象,类是对对象的抽象,对象是类的实例. 在类中来调用方法,不过调用方法也有种种的情况. 在同一个类中的两个方法相互调用; 1.如果两个方法都是普通方法,那么可以直接用 public void eat(){ System.out.println("内容1"); sleep(); } public void sleep(){ System.out.println("内容2"); } 2.如果两个方法都是静态方法,那么可以直接用 publi

C#实现调用Java类中方法

基本思路: 用C#实现调用Java编写的类中的方法:重点是将Java编写的程序打包成Jar,然后使用开源工具IKVM将其转化成DLL控件,在.NET环境下调用. 分为以下步骤: 1.下载JDK6(注:JDK7下可能不支持,建议使用JDK6和Eclipse),进行安装,然后配置环境变量Path,将JDK安装的路径(例如:D:\Program Files\Java\jdk1.6.0_10\bin)添加到Path变量后面,如图所示: 用cmd打开DOS框,输入javac就可以查看是否配置成功,配置成功

python类中方法__str__()和__repr__()简单粗暴总结

在交互式模式下,类中同时实现__str__()和__repr__()方法: 直接输入实例名称显示repr返回的类容: 用print打印实例名称显示str返回的内容: >>> class Test: ... def __repr__(self): ... return 'Test -> return repr' ... def __str__(self): ... return 'Test -> return str' ... >>> t = Test() &

关于一个类中方法调用情况

一.如果两个方法都是普通方法,那么可以直接用方法名调用 public void Happy() { System.out.println("play!") Sleep(); } public void Play() { System.out.println("Sleep!!"); } } } 二.如果两个方法都是静态方法,那么可以直接用方法名调用 public static void Play() { System.out.prinltn("Hello!&