ThinkPHP5开发连载二十九之数据库查询构造器链式操作

上一篇文章讲解“数据库查询构造器-查询表达式”,本篇文章讲解“数据库查询构造器-链式操作”。

数据库提供的链式操作方法,可以有效的提高数据存取的代码清晰度和开发效率,并且支持所有的CURD操作(原生查询不支持链式操作)。

1. 链式操作的使用

使用也比较简单,假如我们现在要查询一个User表的满足状态为1的前10条记录,并希望按照用户的创建时间排序,代码如下:

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

2. CURD方法都可以使用链式操作

不仅仅是查询方法可以使用连贯操作,包括所有的CURD方法都可以使用,例如:

3. 多次服用链式操作

每次Db类的静态方法调用是创建一个新的查询对象实例,如果你需要多次复用使用链式操作值,可以使用下面的方法。

当前查询对象在查询之后仍然会保留链式操作的值,除非你调用removeOption方法清空链式操作的值。

系统支持的链式操作方法包含:

注意:

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

ThinkPHP5连载为卓象程序员原创,转载请联系卓象程序员

关注卓象程序员,定期发布技术文章

下一篇讲解“查询构造器-链式操作的方法”

  • 发表于:
  • 原文链接:https://kuaibao.qq.com/s/20180825A0OG9M00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券