thinkphp:数据库查询,嵌套别的表的查询(别的表做子查询)

例子

  1. vendors 表中选择记录。
  2. vendors 表中,筛选出具有满足以下条件的 vendor_code 值:
    • 对应的采购订单(在 po_headers_all 表中)存在未完全接收的采购行(在 po_lines_all 表中)。
    • 相应的采购订单状态为 "已签核"。
    • 采购行的数量大于已接收数量。
  3. 查询结果按照 vendor_code 字段降序排列,并限制返回的结果集的起始位置和数量。

代码

php 复制代码
$data['all_info'] = Db::table('vendors')
    ->alias('d')
     ->whereExists(function ($query) {
        $query->table('po_headers_all')
            ->alias('a')
            ->join(['po_lines_all'=>'b'], 'a.po_num = b.po_num')
            ->where('b.quantity', '>', Db::raw('b.quantity_received'))
            ->where('a.status', '已签核')
            ->where('a.vendor_code = d.vendor_code');
    })
    ->order('vendor_code', 'desc')
    ->limit($start,$pageSize)
    ->select();

逐句解析

  • $data['all_info'] = Db::table('vendors'): 创建了一个变量 $data['all_info'],用于存储查询结果。使用 Db::table('vendors') 指定了要查询的数据表为 "vendors"。

  • ->alias('d'): 使用别名 "d" 来表示数据表 "vendors"。

  • ->whereExists(function ($query) { ... }): 使用 whereExists 方法来指定一个子查询。子查询中的条件将用来检查是否存在满足条件的记录。

  • $query->table('po_headers_all')->alias('a'): 在子查询中,指定要查询的数据表为 "po_headers_all",并使用别名 "a" 来表示该表。

  • ->join(['po_lines_all'=>'b'], 'a.po_num = b.po_num'): 将数据表 "po_headers_all" 与 "po_lines_all" 进行连接,连接条件是 "a.po_num = b.po_num"。

  • ->where('b.quantity', '>', Db::raw('b.quantity_received')): 在连接后的数据表中,添加条件 "b.quantity > b.quantity_received"。这个条件用来筛选数量未完全接收的记录。

  • ->where('a.status', '已签核'): 添加条件 "a.status = '已签核'",用来筛选状态为 "已签核" 的记录。

  • ->where('a.vendor_code = d.vendor_code'): 添加条件 "a.vendor_code = d.vendor_code",将子查询中的 vendor_code 与主查询中的 vendor_code 进行比较,以确保查询结果中的记录是符合条件的。

  • ->order('vendor_code', 'desc'): 根据 vendor_code 字段降序排序查询结果。

  • ->limit($start, $pageSize): 指定查询结果的分页限制,从 $start 开始,取 $pageSize 条记录。

  • ->select(): 执行查询操作,获取符合条件的记录,并将结果返回给变量 $data['all_info']

查询总数量同理(注:去掉了限制条件)

php 复制代码
$data['total'] = Db::table('vendors')
    ->alias('d')
    ->whereExists(function ($query) {
        $query->table('po_headers_all')
            ->alias('a')
            ->join(['po_lines_all'=>'b'], 'a.po_num = b.po_num')
            ->where('b.quantity', '>', Db::raw('b.quantity_received'))
            ->where('a.status', '已签核')
            ->where('a.vendor_code = d.vendor_code');
    })
    ->count();
相关推荐
成工小白17 分钟前
网络复习(1)
服务器·网络·php
醇氧31 分钟前
SqlLogInterceptor mybatis配置打印SQL
java·sql·mybatis
huahualaly1 小时前
重建oracle测试库步骤
数据库·oracle·ffmpeg
墨香幽梦客1 小时前
数据库选型对比:MySQL、Oracle与PostgreSQL的企业应用场景分析
数据库·mysql·oracle
wei_shuo1 小时前
多模一体破局:金仓数据库引领文档数据库国产化新征程
数据库·金仓数据库
Coder_Boy_1 小时前
基于SpringAI的在线考试系统-数据库 表结构 & 完整外键依赖关系梳理
java·数据库·人工智能·软件工程
恃宠而骄的佩奇1 小时前
蚁剑 php一句话木马简单免杀(编码)绕过360,火绒
开发语言·web安全·php·免杀·一句话木马·火绒安全
清风拂山岗 明月照大江1 小时前
MySQL进阶
数据库·sql·mysql
努力进修1 小时前
金仓数据库:多模融合内核驱动,重构国产化文档数据库新生态
数据库·重构
Miss_Chenzr1 小时前
Springboot企业人事管理系统mi130(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot