ThinkPHP中的连贯操作(重要)
什么是连贯操作?
所谓的连贯操作就是将辅助方法全部写在一行上的写法,这样的形式叫做连贯操作。
也就是如下的形式:
$model -> where() -> limit() -> field() -> order() ->group() -> select();
注意:辅助方法的顺序没有要求,只要符合模型在最前面,CURD操作在最后面即可。
案例:使用group的方法去查询部门表,要求查询出部门名称和出现的次数。
原生的sql语句:select name,count(*) from oa_dept group by name;
使用连贯操作改写:
//连贯操作
public function test(){
//实例化模型
$model = M('Dept');
//连贯操作
$result = $model -> group('name') -> field('name,count(*)') -> select();
//打印
dump($result);
}
显示结果:
sql跟踪信息中的结果:
数据库中的信息:
那么为什么辅助方法能够写在一行上呢?
原因就是每一个辅助方法的返回值都是$this,$this是指当前的模型类,由当前的模型类去调用后续的辅助方法。
父类模型中的辅助方法返回值:
$model -> group('name') -> field('name,count(*)') -> select();相当于$this -> field('name,count(*)') -> select();又相当于$this -> select();
所以辅助方法能够同时写在一行上。
注意:在以后的开发时,不论是自己还是别人写的代码,都会遵循连贯操作的形式来代替每一个辅助方法单独写一行的写法。