首页 > 作文

tp5.1框架数据库子查询操作实例分析

更新时间:2023-04-08 18:05:04 阅读: 评论:0

本文实例讲述了tp5.1框架数据库子查询操作。分享给大家供大家参考,具体如下:

首先构造子查询sql,可以使用下面三种的方式来构建子查询。

使用fetchsql方法

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 

使用buildsql构造子查询

$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 inexists/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 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图