脚本宝典收集整理的这篇文章主要介绍了详解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条件的几个知识点:
@H_304_40@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添加where条件的问题分析全部内容,希望文章能够帮你解决详解mysql 使用left join添加where条件的问题分析所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。