ThinkPHP3.0完全开发手册                                           

 

6.12               连贯操作

ThinkPHP模型基础类提供的T连贯操作T方法,可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作。使用也比较简单, 假如我们现在要查询一个User表的满足状态为1的前10条记录,并希望按照用户的创建时间排序 ,代码如下:

$User->where('status=1')->order('create_time')->limit(10)->select();

这里的whereorderlimit方法就被称之为连贯操作方法T除了select方法必须放到最后一个外(因为select方法并不是连贯操作方法),连贯操作T的方法调用顺序没有先后,例如,下面的代码和上面的等效:

$User->order('create_time')->limit(10)->where('status=1')->select();

如果不习惯使用连贯操作的话,还支持直接使用参数进行查询的方式。例如上面的代码可以改写为:

$User->select(array('order'=>'create_time','where'=>'status=1','limit'=>'10'));

使用数组参数方式的话,索引的名称就是连贯操作的方法名称。其实T不仅仅是查询方法可以使用连贯操作,包括所有的CURD方法都可以使用,例如:

$User->where('id=1')->field('id,name,email')->find(); 

$User->where('status=1 and id=1')->delete();

 

连贯操作通常只有一个参数,并且仅在当此查询或者操作有效,完成后会自动清空连贯操作的所有传值(有个别特殊的连贯操作有多个参数,并且会记录当前的传值)。简而言之,连贯操作的结果不会带入以后的查询。

系统支持的连贯操作方法有:

连贯操作

作用

支持的参数类型

where

用于查询或者更新条件的定义

字符串、数组和对象

table

用于定义要操作的数据表名称

字符串和数组

alias

用于给当前数据表定义别名

字符串

data

用于新增或者更新数据之前的数据对象赋值

数组和对象

field

用于定义要查询的字段(支持字段排除)

字符串和数组

order

用于对结果排序

字符串和数组

limit

用于限制查询结果数量

字符串和数字

page

用于查询分页(内部会转换成limit

字符串和数字

group

用于对查询的group支持

字符串

having

用于对查询的having支持

字符串

join*

用于对查询的join支持

字符串和数组

union*

用于对查询的union支持

字符串、数组和对象

distinct

用于查询的distinct支持

布尔值

lock

用于数据库的锁机制

布尔值

cache

用于查询缓存

支持多个参数

relation

用于关联查询(需要关联模型支持)

字符串

所有的连贯操作都返回当前的模型实例对象(this),其中带*标识的表示支持多次调用。


NetPc