用户登录
用户注册

分享至

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

  • 作者: 你家白妮
  • 来源: 51数据库
  • 2021-08-31

本文实例讲述了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 ) 
软件
前端设计
程序设计
Java相关