当前位置: 首页 > news >正文

MySql数据库left join中添加子查询

user表查询出数据列表(多条,如id)左连接到order表中的order_agent_id字段,并通过 order_agent_id分组,求和user_order_partner,使用COALESCE()聚合函数对未获取到和值的进行默认赋值,防止查询不出数据不显示问题

SELECT COUNT(*)
FROM (SELECT t.id,t1.create_time AS createTime,t.user_nickname,t.user_image AS userImg,t.user_tel,COALESCE(t1.total_price, '0.00') AS priceFROM db_user tLEFT JOIN (SELECT order_agent_id, create_time, COALESCE(SUM(user_order_partner), '0.00') AS total_priceFROM db_user_orderWHERE order_status = 1 AND deleted = 0GROUP BY order_agent_id, create_time) AS t1 ON t.id = t1.order_agent_idWHERE t.deleted = 0 AND (t.user_partner_id = ? AND t.user_level <> ?)ORDER BY t1.total_price DESC
) AS TOTAL;
  1. 最外层查询‌:

    SELECT COUNT(*) FROM (...) AS TOTAL;

    这部分查询计算内部查询(即括号内的查询)返回的行数。TOTAL是一个别名,用于表示内部查询的结果集。

  2. 内部查询‌:

        SELECT t.id,t1.create_time AS createTime,t.user_nickname,t.user_image AS userImg,t.user_tel,COALESCE(t1.total_price, '0.00') AS priceFROM db_user tLEFT JOIN (SELECT order_agent_id, create_time, COALESCE(SUM(user_order_partner), '0.00') AS total_priceFROM db_user_orderWHERE order_status = 1 AND deleted = 0GROUP BY order_agent_id, create_time) AS t1 ON t.id = t1.order_agent_idWHERE t.deleted = 0 AND (t.user_partner_id = ? AND t.user_level <> ?)ORDER BY t1.total_price DESC

    这部分查询执行以下操作:

    • db_user表中选择用户信息。
    • 通过左连接(LEFT JOIN)将db_user表与一个子查询结果连接。子查询从db_user_order表中计算每个order_agent_idcreate_time组合的订单总额(user_order_partner的和)。
    • 使用COALESCE函数确保如果total_priceNULL,则将其替换为'0.00'。上面的COALESCE(t1.total_price, '0.00') AS price直接可以调整成total_price AS price,因为在下面已经对total_price的NULL,替换了
    • 应用WHERE子句来过滤出未删除的用户,并且其user_partner_id等于某个值且user_level不等于另一个值。
    • 使用ORDER BY子句按total_price降序排序结果。
  3. 参数占位符‌:
    查询中的?是参数占位符,用于在执行查询时提供具体的值。例如,t.user_partner_id = ?中的?应该被替换为一个具体的用户伙伴ID值。

  4. 结果‌:
    最终,这个查询返回一个数字,表示满足条件的用户订单记录的数量。注意,尽管内部查询包含ORDER BY子句,但外部查询的COUNT(*)并不关心行的顺序,它只计算行数。

在实际应用中,需要替换占位符?为具体的值,并执行这个查询来获取结果。这个查询可能用于报告或分析目的,以了解有多少用户满足特定的订单和用户条件。

http://www.lryc.cn/news/462006.html

相关文章:

  • redis--过期策略和内存淘汰策略
  • qt QTableview 左侧 序号 倒序
  • 隧道代理IP如何帮助企业采集数据?
  • Spring Boot知识管理系统:技术与方法论
  • SpringBoot1~~~
  • 兼容多家品牌手机的多协议取电快充芯片
  • Java和Python的不同
  • Moshang摩熵医药数据库
  • 基于web的酒店客房管理系统【附源码】
  • 潜水定位通信系统的功能和使用方法_鼎跃安全
  • Golang | Leetcode Golang题解之第477题汉明距离总和
  • JavaWeb——Maven(1/8):整体介绍(什么是Maven、Maven的作用、小结)
  • Vivado 跟Xilinx SAE学HLS系列-高亚军(复合数据类型)
  • 【mysql】WITH AS 语法详解
  • Rocky linux SSD安装
  • 在 Linux 系统中设置 Service 服务开机自启的详细指南
  • Flythings学习(四)串口通信
  • [数据结构]带头双向循环链表的实现与应用
  • 商品详情数据API接口开发系列(属性规格详情图sku等)
  • 在 Ubuntu 上安装 clang-format-14
  • 【优选算法篇】双指针的华丽探戈:深入C++算法殿堂的优雅追寻
  • 【springboot入门-mvc常用注解使用方式及原理】
  • 滚雪球学Redis[4.2讲]:Redis Sentinel 深度解析:工作原理、配置与高可用架构下的故障转移
  • Vue3 -- 设置分页,切换分页之后选项仍能保留 控制多个表格的选中不会互相影响
  • 如何在 JSON 中编写“anyOf”语句?
  • python开发环境配置
  • QT开发--QT SQL模块
  • 如何保证接口幂等性?
  • 【9718】基于springboot+vue的生鲜交易系统
  • Spring循环依赖解决方案