【联表查询中的隐蔽 bug】

join、left join

  • JOIN(INNER JOIN)是选择两个表中都有的记录,结果集会排除掉任何不匹配的记录。
  • LEFT JOIN是选择左表的所有记录,右表的记录如果存在则包括在内,不存在则用NULL填充。

举例

前提介绍

  • 下面的sq大致看上去好像没问题。
  • 有三张表 (users用户表、orders订单表、order_user用户和订单的关联表表示参加这个订单的用户) 。
  • 很明显,这个sql对应的需求应该是查询所有订单,并且联表查询出参加这个订单的用户,也就是及时这个订单没有用户参与也要将这条订单查出。
  • 但是,现在情况是当order_user没有记录与orders对应时,这条订单不能被查出。
sql 复制代码
select orders.id             AS order_id,
      // ... 省略一些字段
       orders.description    AS order_description,
       
       users.id              AS user_id,
        // ... 省略一些字段
       users.description     AS user_description
from orders
         join order_user on orders.id = order_user.order_id
         left join users on users.id = order_user.user_id
where orders.is_delete = 0
and order_user.is_delete = 0
and users.is_delete = 0;

问题分析

上面的sql问题出在where后面的条件上,虽然left join不会管右边有没有用户相匹配,但是,where后面的isdelete=0会过滤掉右边为空的记录。

解决办法

将isdelete判断变成联表查询的并列条件。

sql 复制代码
select orders.id             AS order_id,
      // ... 省略一些字段
       orders.description    AS order_description,
       
       users.id              AS user_id,
        // ... 省略一些字段
       users.description     AS user_description
from orders
         left join order_user on orders.id = order_user.order_id and order_user.is_delete = 0
         left join users on users.id = order_user.user_id and users.is_delete = 0
where orders.is_delete = 0;
相关推荐
JIngJaneIL1 天前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼1 天前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
小光学长1 天前
基于Vue的智慧楼宇报修平台设计与实现066z15wb(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
CodeBlossom1 天前
Spring Cache快速入门
java·数据库·spring
tuokuac1 天前
ps -ef | grep redis
数据库·redis·缓存
⑩-1 天前
如何保证Redis和Mysql数据缓存一致性?
java·数据库·redis·mysql·spring·缓存·java-ee
征尘bjajmd1 天前
Java使用okhttp发送get、post请求
java·服务器·数据库
清风6666661 天前
基于单片机的智能高温消毒与烘干系统设计
数据库·单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
Databend1 天前
Databend 十月月报:存储过程正式可用,数据流程全面自动化
数据库
wangjialelele1 天前
MySQL操作库
数据库·mysql·oracle