学习
实践
活动
专区
工具
TVP
写文章

thinkphp5数据库查询构造器子查询

上一篇文章讲解“数据库查询构造器-JSON字段”,本篇文章讲解“数据库查询构造器-子查询”。首先构造子查询SQL,可以使用下面三种的方式来构建子查询。1.使用fetchSql方法fetchSql方法表示不进行查询而只是返回构建的SQL语句,并且不仅仅支持select,而是支持所有的CURD查询。新建Index控制器,并新建sqlFun方法:

预览:2.使用buildSql构造子查询在Index控制器中,新建buildFun方法:

预览:调用buildSql方法后不会进行实际的查询操作,而只是生成该次查询的SQL语句(为了避免混淆,会在SQL两边加上括号),然后我们直接在后续的查询中直接调用。修改Index控制器下的buildFun方法:

预览:

生成的SQL语句:

3.使用闭包构造子查询IN/NOTIN和EXISTS/NOTEXISTS之类的查询可以直接使用闭包作为子查询。1)IN/NOTIN在Index控制器中,新建closeFun方法:

预览:

2)EXISTS/NOTEXISTS修改Index控制器下的closeFun方法:

预览:

注意:除了上述查询条件外,比较运算也支持使用闭包子查询。ThinkPHP5连载为卓象程序员原创,转载请联系卓象程序员关注卓象程序员,定期发布技术文章下一篇讲解“查询构造器-原生查询”

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20181001A0LF2C00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

关注

腾讯云开发者公众号
10元无门槛代金券
洞察腾讯核心技术
剖析业界实践案例
腾讯云开发者公众号二维码

扫码关注腾讯云开发者

领取腾讯云代金券