028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

如何在mysql中使用leftjoin添加where条件-创新互联

如何在mysql中使用left join添加where条件?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

创新互联建站公司2013年成立,先为翁牛特等服务建站,翁牛特等地企业,进行企业商务咨询服务。为翁牛特企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

当前需求:

有group和factor两张表,一个group对应多个factor,现在想查询有效的group和对应的有效的factor,两个表都有isDel逻辑删除标志。

如何在mysql中使用left join添加where条件

最开始的错误写法一

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条件的几个知识点:

正确的写法:

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中使用leftjoin添加where条件-创新互联
网页URL:http://www.tsicrk.com/article/cdjdge.html

其他资讯

让你的专属顾问为你服务

2.5094s