欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-09-04 13:48:03
本文实例讲述了tp5.1框架数据库子查询操作。分享给大家供大家参考,具体如下:首先构造子查询sql,可以使用下面三种的方式来构建子查询。使用fetchsql方法fetchsql方法表示不进行查询而只是...

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

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

使用fetchsql方法

fetchsql方法表示不进行查询而只是返回构建的sql语句,并且不仅仅支持select,而是支持所有的curd查询。

$subquery = db::table('think_user')
 ->field('id,name')
 ->where('id', '>', 10)
 ->fetchsql(true)
 ->select();

生成的subquery结果为:

select `id`,`name` from `think_user` where `id` > 10 

使用buildsql构造子查询

$subquery = db::table('think_user')
 ->field('id,name')
 ->where('id', '>', 10)
 ->buildsql();

生成的subquery结果为:

( select `id`,`name` from `think_user` where `id` > 10 )

调用buildsql方法后不会进行实际的查询操作,而只是生成该次查询的sql语句(为了避免混淆,会在sql两边加上括号),然后我们直接在后续的查询中直接调用。

然后使用子查询构造新的查询:

db::table($subquery . ' a')
 ->where('a.name', 'like', 'thinkphp')
 ->order('id', 'desc')
 ->select();

生成的sql语句为:

select * from ( 
 select `id`,`name` from `think_user` where `id` > 10 ) a 
where 
 a.name like 'thinkphp' 
order by 
 `id` 
desc

使用闭包构造子查询

in/not inexists/not exists之类的查询可以直接使用闭包作为子查询,例如:

db::table('think_user')
 ->where('id', 'in', function ($query) {
  $query->table('think_profile')->where('status', 1)->field('id');
 })
 ->select();

生成的sql语句是

select * from `think_user` 
where `id` in ( select `id` from `think_profile` where `status` = 1 )
db::table('think_user')
 ->whereexists(function ($query) {
  $query->table('think_profile')->where('status', 1);
 })->find();

生成的sql语句为

select * from `think_user` 
where exists ( select * from `think_profile` where `status` = 1 )