主页 > 知识库 > 详解mysql 使用left join添加where条件的问题分析

详解mysql 使用left join添加where条件的问题分析

热门标签:怎样在地图标注销售区域 百应电话机器人优势 外呼系统打电话上限是多少 地图标注费用是多少 电话外呼系统改号 啥是企业400电话办理 武汉网络外呼系统服务商 曲靖移动外呼系统公司 南昌三维地图标注

当前需求:

有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设置条件在on与where时的用法区别分析
  • MySQL left join操作中on和where放置条件的区别介绍
  • 解析mysql left( right ) join使用on与where筛选的差异

标签:黑河 沧州 随州 资阳 吉林 锦州 荆州 甘南

巨人网络通讯声明:本文标题《详解mysql 使用left join添加where条件的问题分析》,本文关键词  详解,mysql,使用,left,join,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《详解mysql 使用left join添加where条件的问题分析》相关的同类信息!
  • 本页收集关于详解mysql 使用left join添加where条件的问题分析的相关信息资讯供网民参考!
  • 推荐文章