上一篇文章讲解“数据库查询构造器-查询表达式”,本篇文章讲解“数据库查询构造器-链式操作”。
数据库提供的链式操作方法,可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作(原生查询不支持链式操作)。
1. 链式操作的使用
使用也比较简单,假如我们现在要查询一个User表的满足状态为1的前10条记录,并希望按照用户的创建时间排序,代码如下:
这里的where、order和limit方法就被称之为链式操作方法,除了select方法必须放到最后一个外(因为select方法并不是链式操作方法),链式操作的方法调用顺序没有先后,例如,下面的代码和上面的等效:
2. CURD方法都可以使用链式操作
不仅仅是查询方法可以使用连贯操作,包括所有的CURD方法都可以使用,例如:
3. 多次服用链式操作
每次Db类的静态方法调用是创建一个新的查询对象实例,如果你需要多次复用使用链式操作值,可以使用下面的方法。
当前查询对象在查询之后仍然会保留链式操作的值,除非你调用removeOption方法清空链式操作的值。
系统支持的链式操作方法包含:
注意:
1. 所有的连贯操作都返回当前的模型实例对象(this),其中带*标识的表示支持多次调用。
ThinkPHP5连载为卓象程序员原创,转载请联系卓象程序员
关注卓象程序员,定期发布技术文章
下一篇讲解“查询构造器-链式操作的方法”