详解mysql 使用left join添加where条件的问题分析
当前需求:
有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志。
最开始的错误写法一:
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id where g.isDel=0 and f.isDel=0
LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。
上边这样写左边表要是在右边表没有对应数据是查询不出来的,原因就是f.isDel=0
这个代码问题。
错误写法二:
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and g.isDel=0 and f.isDel=0
这种写法g.isDel=0
是不会生效的,导致查询数据根本不对。
原因分析:
left join中关于where和on条件的几个知识点:
- 多表left join是会生成一张临时表,并返回给用户
- where条件是针对最后生成的这张临时表进行过滤,过滤掉不符合where条件的记录
- on条件是对left join的右表进行条件过滤,但依然返回左表的所有行,右表中没有的补为NULL
- on条件中如果有对左表的限制条件,无论条件真假,依然返回左表的所有行,但是会影响右表的匹配值。也就是说on中左表的限制条件只影响右表的匹配内容,不影响返回行数。
正确的写法:
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and f.isDel=0 where g.isDel=0
结论:
1.对左表添加条件限制需在where条件中添加,不能放到on后面
2.对右表添加条件限制需放到on后面,在where条件中添加会有数据行数差异出现问题。
到此这篇关于详解mysql 使用left join添加where条件的问题分析的文章就介绍到这了,更多相关mysql left join添加where内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- 图文详解Mysql使用left join写查询语句执行很慢问题的解决
- mysql使用left join连接出现重复问题的记录
- MySQL中多个left join on关联条件的顺序说明
- 关于mysql left join 查询慢时间长的踩坑总结
- MYSQL Left Join优化(10秒优化到20毫秒内)
- 解决Mysql的left join无效及使用的注意事项说明
- mysql left join快速转inner join的过程
- mysql高效查询left join和group by(加索引)
- mysql中left join设置条件在on与where时的用法区别分析
- MySQL 8.0.18 Hash Join不支持left/right join左右连接问题
- MySQL left join操作中on和where放置条件的区别介绍
- mysql多个left join连接查询用法分析
- MySQL利用profile分析慢sql详解(group left join效率高于子查询)
- MySQL在右表数据不唯一的情况下使用left join的方法
- MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程
- mysql left join的基本用法以及on与where的区别
相关文章
MYSQL根据分组获取组内多条数据中符合条件的一条(实例详解)
这篇文章主要介绍了MYSQL根据分组获取组内多条数据中符合条件的一条,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-06-06Mysql ERROR 1067: Invalid default v
这篇文章主要介绍了Mysql ERROR 1067: Invalid default value for字段问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-05-05Windows系统中完全卸载MySQL数据库实现重装mysql
这篇文章主要介绍了Windows系统中完全卸载MySQL数据库实现重装mysql数据库的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下吧2018-05-05
最新评论