上一篇文章讲解“数据库查询构造器-JSON字段”,本篇文章讲解“数据库查询构造器-子查询”。
首先构造子查询SQL,可以使用下面三种的方式来构建子查询。
1. 使用fetchSql方法
fetchSql方法表示不进行查询而只是返回构建的SQL语句,并且不仅仅支持select,而是支持所有的CURD查询。
新建Index控制器,并新建sqlFun方法:
预览:
2. 使用buildSql构造子查询
在Index控制器中,新建buildFun方法:
预览:
调用buildSql方法后不会进行实际的查询操作,而只是生成该次查询的SQL语句(为了避免混淆,会在SQL两边加上括号),然后我们直接在后续的查询中直接调用。
修改Index控制器下的buildFun方法:
预览:
生成的SQL语句:
3. 使用闭包构造子查询
IN/NOT IN和EXISTS/NOT EXISTS之类的查询可以直接使用闭包作为子查询。
1)IN/NOT IN
在Index控制器中,新建closeFun方法:
预览:
2)EXISTS/NOT EXISTS
修改Index控制器下的closeFun方法:
预览:
注意:
除了上述查询条件外,比较运算也支持使用闭包子查询。
ThinkPHP5连载为卓象程序员原创,转载请联系卓象程序员
关注卓象程序员,定期发布技术文章
下一篇讲解“查询构造器-原生查询”
领取专属 10元无门槛券
私享最新 技术干货