多表关联查询,join on 条件不生效,无法筛选记录

多表关联查询,join on 条件不生效,无法筛选记录

MySQL、left join、join on、筛选、多表关联查询

背景

  • 环境版本:局域网-win10-MySQL5.6
  • 业务场景:MySQL多表联查,意图把查询条件按照关键字执行顺序往前提,尽可能降低数据库查询对性能的占用。

问题描述

  • 现象(简化)

现有两个表doc(key,time)(这是个列转行后的虚表)、main(key,id)(实体表),程序中执行:

select d.key,m.id,d.time
from doc d
         left join main m on m.id is not null and d.time >= '2023-11-15'

doc表中没有15号以后的数据,但是在运行结果中,不符合这个条件的doc数据仍然存在。手动拼写sql语句执行,发现不合条件语句仍然存在。
然而应与其关联的子表的数据(m.id)均为null

原因分析

不难想到,这是因为关联条件on加到了子表上,没有控制到主表。

解决方案

将d.time筛选条件外移一层,用where查询,例如:

select d.key, m.id, d.time
from doc d
         left join main m on m.id is not null
where d.time >= '2023-11-15'

声明:本文使用八爪鱼rpa工具从gitee自动搬运本人原创(或摘录,会备注出处)博客,如版式错乱请评论私信,如情况紧急或久未回复请致邮 xkm.0jiejie0@qq.com 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值