多表关联查询,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 并备注原委;引用本人笔记的链接正常情况下均可访问,如打不开请查看该链接末尾的笔记标题(右击链接文本,点击 复制链接地址,在文本编辑工具粘贴查看,也可在搜索框粘贴后直接编辑然后搜索),在本人博客手动搜索该标题即可;如遇任何问题,或有更佳方案,欢迎与我沟通!