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

作者:码厚炮 时间:2024-01-15 18:30:27 

当前需求:

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

  • 多表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条件中添加会有数据行数差异出现问题。

来源:https://blog.csdn.net/weixin_40300139/article/details/107662160

标签:mysql,left,join,where
0
投稿

猜你喜欢

  • 浅析Vue自定义组件的v-model

    2024-04-29 13:10:16
  • mysql数据库索引损坏及修复经验分享

    2024-01-16 11:22:43
  • asp和js两种方法判断远程图片是否存在

    2007-09-21 17:27:00
  • Python自然语言处理 NLTK 库用法入门教程【经典】

    2022-10-06 04:36:54
  • CSS3创建惊艳多重边框色

    2010-07-23 10:13:00
  • php指定长度分割字符串str_split函数用法示例

    2023-07-08 23:25:51
  • C#使用ADO.Net连接数据库与DbProviderFactory实现多数据库访问

    2024-01-24 08:56:29
  • sql使用cast进行数据类型转换示例

    2024-01-14 07:42:11
  • 自定义PyCharm快捷键的设置方式

    2023-11-20 08:28:08
  • python Celery定时任务的示例

    2023-12-28 14:08:39
  • PHP 中关于ord($str)>0x80的详细说明

    2024-05-13 09:24:13
  • Python中的各种装饰器详解

    2023-02-23 06:16:41
  • Python操作Sql Server 2008数据库的方法详解

    2024-01-20 04:47:01
  • SQL Server实现group_concat功能的详细实例

    2024-01-20 11:15:47
  • python Django框架实现web端分页呈现数据

    2022-07-03 03:47:14
  • VBScript运行出错信息涵义列表

    2007-08-12 18:03:00
  • 基于numpy实现逻辑回归

    2023-06-21 10:04:25
  • Linux 7下脚本安装配置oracle 11g r2教程

    2024-01-13 13:35:56
  • python turtle绘图命令及案例

    2022-04-29 10:26:58
  • TMDPHP 模板引擎使用教程

    2023-11-15 03:21:56
  • asp之家 网络编程 m.aspxhome.com