本文实例讲述了tp5.1框架数据库子查询操作。分享给大家供大家参考,具体如下:
首先构造子查询sql,可以使用下面三种的方式来构建子查询。
fetchsql方法表示不进行查询而只是返回构建的sql语句,并且不仅仅支持lect
,而是支持所有的curd查询。
$subquery = db::table('think_ur') ->field('id,name') ->where('id', '>', 10) ->fetchsql(true) ->lect();
生成的subquery结果为:
lect `id`,`name` from `think_ur` where `id` > 10
$subquery = db::table('think_ur') ->field('id,name') ->where('id', '>', 10) ->buildsql();
生成的subquery结果为:
( lect `id`,`name` from `think_ur`留学费用一览表 where `id` > 10 )
调用buildsql方法后不会进行实际的查询操作,而只是生成该次查询的sql语句(为了避免混淆,会在sql两边加上括号),然后我们直接在后续的查询中直接调用。
然后使用子查询构造新的查询:
db::table($subquery . ' a') ->where('a.na法学就业前景me', 'like', 'thinkphp') ->order('id', 'desc') ->lect();
生成的sql语句为:
lect * from ( l励志的句子简短ect `id`,`name` from `think_ur` where `id` > 10 ) a where a.name like 'thinkphp' order by `id` desc
in/not in
和exists/not exists
之类的查询可以直接使用闭包作为子查询,例如:
db::table('think_ur') ->where('id', 'in', function ($query) { $query->table('think_profile')->where('status', 1)->field('id'); }) ->lect();
生成的sql语句是
lect * from `think_ur` 最早种植水稻的是哪个国家where `id` in ( lect `id` from `think_profile` where `status` = 1 )
db::table('think_ur')坚韧不拔 ->whereexists(function ($query) { $query->table('think_profile')->where('status', 1); })->find();
生成的sql语句为
lect * from `think_ur` where exists ( lect * from `think_profile` where `status` = 1 )
本文发布于:2023-04-08 18:05:02,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/4e9894adb87b604d22e3c222c2bb982f.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:tp5.1框架数据库子查询操作实例分析.doc
本文 PDF 下载地址:tp5.1框架数据库子查询操作实例分析.pdf
留言与评论(共有 0 条评论) |