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

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


http://www.kler.cn/news/357961.html

相关文章:

  • 单片机裸机程序 —— 设计模式
  • 机器人大功率主轴SycoTec 4060 ER-S汽车电机机芯焊缝铣削打磨加工
  • 数据结构-B树和B+树
  • java设计模式——装饰者模式
  • 详解equals底层原理
  • 【力扣打卡系列】滑动窗口与双指针(无重复字符的最长子串)
  • word取消自动单词首字母大写
  • OpenAI Prompt generation - 生成和优化Prompt的Prompt
  • distinct 和 group by
  • 恒定电流下有功率密度,功率密度体积分就是恒定电流的功率
  • 2024最新 无人机 数据集(不定期更新)
  • 【flutter】哪些APP使用了flutter框架开发
  • 如何修改jupyter notebook的工作目录
  • Chromium 加载chrome.dll过程分析c++
  • 使用Spring Boot打造中小型医院网站
  • 使用Three.js和Force-Directed Graph实现3D知识图谱可视化
  • 【高等数学学习记录】极限存在准则,两个重要极限
  • bash之流程控制
  • 基于SSM+微信小程序的电子点餐管理系统(点餐1)
  • 电影评论网站:Spring Boot技术实践