LEFT JOIN条件在on后面和在where后面的区别及说明

 更新时间:2023年09月01日 09:39:53   作者:夜白宋  
这篇文章主要介绍了LEFT JOIN条件在on后面和在where后面的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、left join 的实际运用

left join 一般用于显示左边所有数据,并携带右表的数据;

而在on后面进行条件过滤,只会过滤掉右表条件不为真的数据,左表数据一定会显示;

在where后面进行条件过滤,是对左表右表的结果表进行过滤,所以数据不一定能完全显示。

二、两表联查SQL区别

存在数据表test1, test4

test1:

在这里插入图片描述

test4:

在这里插入图片描述

1、在on后面补全条件

select * from test1 left join test4 on test1.id = test4.id and test4.is_effective = 1

在这里插入图片描述

可以发现test1中的数据全部被读取,test4中过滤了is_effective != 1的数据

2、在where后面补全条件

select * from test1 left join test4 on test1.id = test4.id where test4.is_effective = 1

在这里插入图片描述

可以发现只显示了test1中的id为1的数据内容。

三、三表联查SQL区别

存在test1,test2,test3三张表,其中test3是test1和test2的中间表

test1:

在这里插入图片描述

test2:

在这里插入图片描述

test3:

在这里插入图片描述

某些业务中,我们会使用中间表查询数据,如果存在业务,要显示test1中的全部数据,并携带test2中的有效数据,我们一般会采用left join 去完成sql,而这时需要注意应该将test2和test3的结果表作为整个右表,才能正常完成业务。

1.错误示范:

1.1 连续使用left join,on后面过滤条件

SELECT
	* 
FROM
	test1
	LEFT JOIN test3 ON test1.id = test3.id1
	LEFT JOIN test2 ON test2.id = test3.id2 and is_effective = 1

在这里插入图片描述

会查出test1中的重复数据

1.2 连续使用left join,where后面过滤条件

SELECT
	* 
FROM
	test1
	LEFT JOIN test3 ON test1.id = test3.id1
	LEFT JOIN test2 ON test2.id = test3.id2 
WHERE
	is_effective = 1

在这里插入图片描述

无法完全显示test1中的数据

2.正确操作 

2.1将test2和test3作为整个右表查询

SELECT
	* 
FROM
	test1
	LEFT JOIN ( SELECT * FROM test2 INNER JOIN test3 ON test2.id = test3.id2 WHERE is_effective = 1 ) b ON test1.id = b.id1

在这里插入图片描述

正常完成查询

四、结论

1.用left join 进行条件过滤时,on条件只会对右表进行条件过滤,不会对左表数据产生任何影响;

2.用left join 进行条件过滤时,where条件会对结果表进行条件过滤,所以会对左表数据产生影响;

3.用inner join 用on和where没有任何区别

好了,以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL普通表如何转换成分区表

    MySQL普通表如何转换成分区表

    分表和表分区的目的就是减少数据库的负担,提高数据库的效率,通常点来讲就是提高表的增删改查效率,下面这篇文章主要给大家介绍了关于MySQL普通表如何转换成分区表的相关资料,需要的朋友可以参考下
    2022-05-05
  • mysql之连接超时wait_timeout问题及解决方案

    mysql之连接超时wait_timeout问题及解决方案

    这篇文章主要介绍了mysql之连接超时wait_timeout问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • MySQL学习笔记之数据的增、删、改实现方法

    MySQL学习笔记之数据的增、删、改实现方法

    这篇文章主要介绍了MySQL学习笔记之数据的增、删、改实现方法,简单介绍了mysql实现数据的增、删、改相关语法与使用技巧,需要的朋友可以参考下
    2016-09-09
  • 解析SQL语句中Replace INTO与INSERT INTO的不同之处

    解析SQL语句中Replace INTO与INSERT INTO的不同之处

    本篇文章是对SQL语句中Replace INTO与INSERT INTO的不同之处进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • mysql幻读详解实例以及解决办法

    mysql幻读详解实例以及解决办法

    MySQL中的幻读只有在读的时候才会发生,读这里特指SELECT操作,下面这篇文章主要给大家介绍了关于mysql幻读详解实例以及解决办法的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • MySQL8.0.32安装及环境配置过程

    MySQL8.0.32安装及环境配置过程

    这篇文章主要介绍了MySQL8.0.32安装以及环境配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • MySQL 不等于的三种使用及区别

    MySQL 不等于的三种使用及区别

    MySQL中常用到判断符号,而不等于是比较常用的符号,不等于主要是三种,本文主要介绍了三种的使用及区别,感兴趣的同学可以了解一下
    2021-06-06
  • MySQL中ROUND函数进行四舍五入操作陷阱分析

    MySQL中ROUND函数进行四舍五入操作陷阱分析

    这篇文章主要介绍了MySQL中ROUND函数进行四舍五入操作陷阱,结合实例形式分析了mysql使用ROUND函数进行四舍五入运算中出现的问题及其错误原因,需要的朋友可以参考下
    2018-06-06
  • mysql 8.0.12 安装配置方法并修改密码

    mysql 8.0.12 安装配置方法并修改密码

    这篇文章主要为大家详细介绍了mysql 8.0.12 安装配置,及修改密码的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Mybatis的where标签使用总结梳理

    Mybatis的where标签使用总结梳理

    这篇文章主要介绍了Mybatis的where标签使用总结梳理,文章通过将Mybatis中where标签的基本使用形式展开where标签小技巧以及容易踩到的坑进行总结梳理,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-05-05

最新评论