Mysql中left join后用on与where的区别全面解析

 更新时间:2026年01月16日 09:28:44   作者:奋斗的狍子007  
ON条件用于定义连接条件,确保左表的所有行都包含在结果集中,而WHERE条件则在连接操作后过滤结果集,可能会排除一些原本应该包含的行,了解这两者的区别对于编写准确的SQL查询至关重要,下面给大家讲解Mysql中left join后用on与where的区别,感兴趣的朋友一起看看吧

一、前言

  前几天项目中,写SQL时本想通过 A left B join on and 后面的条件来使查出的两条记录变成一条,奈何发现还是有两条。在此记录一下,on与where的区别。

二、ON

原始数据展示

SELECT t1.*,t2.* FROM  t_test_staff t1 left join t_test_department t2 on t1.departmentId = t2.id and t;

查询结果

ON后面跟and,左表条件

SELECT t1.*,t2.* FROM  t_test_staff t1 left join t_test_department t2 on t1.departmentId = t2.id and t1.name = '员工1';

查询结果

ON后面跟and,右表条件

SELECT t1.*,t2.* FROM  t_test_staff t1 left join t_test_department t2 on t1.departmentId = t2.id and t2.departmentName = '研发部';

查询结果

  ON 条件用于定义两个表之间的连接条件,它决定了哪些行会被连接在一起。在 LEFT JOIN 中,ON 条件决定了右表(被连接的表)中的哪些行会被匹配到左表(主表)的行。

  在这个例子中,Table1 中的每一行都会出现在结果集中,无论 Table2 中是否有匹配的行。如果 Table2 中有匹配的行,则这些行的数据会被包含进来;如果没有匹配的行,则 Table2 的列会显示为 NULL。

三、where

on后面跟where,左表条件

SELECT t1.*,t2.* FROM  t_test_staff t1 left join t_test_department t2 on t1.departmentId = t2.id where t1.name = '员工1';

查询结果

on后面跟where,右表条件

SELECT t1.*,t2.* FROM  t_test_staff t1 left join t_test_department t2 on t1.departmentId = t2.id where t2.departmentName = '研发部';

查询结果

  WHERE 条件用于过滤结果集,它在连接操作之后应用。这意味着 WHERE 条件会进一步筛选已经通过 ON 条件连接好的结果集。

  在这个例子中,LEFT JOIN 依然会先执行,将 Table1 中的每一行与 Table2 中的匹配行连接起来(如果有的话)。然后,WHERE 条件会过滤掉那些 Table2.some_column 为 NULL 的行。

  由于 LEFT JOIN 保证了 Table1 中的每一行都会出现在结果集中,WHERE 条件实际上将结果集转换为了一个类似于 INNER JOIN 的结果集,因为它排除了所有 Table2 中没有匹配行的 Table1 行(即 Table2 列值为 NULL 的行)。

四、总结

  ON 条件:用于定义连接条件,决定如何连接两个表。在 LEFT JOIN 中,它会保留左表中的所有行,并根据条件匹配右表中的行。

  WHERE 条件:用于过滤结果集,它在连接操作之后应用。在 LEFT JOIN 中,使用 WHERE 条件可以进一步筛选结果集,但需要注意它会排除所有不满足条件的行,包括那些由于 LEFT JOIN 而产生的 NULL 值行。

到此这篇关于Mysql中left join后用on与where的区别全面解析的文章就介绍到这了,更多相关mysql left join on与where区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL 随机查询数据与随机更新数据实现代码

    MySQL 随机查询数据与随机更新数据实现代码

    以下的文章主要讲述的是MySQL随机查询数据、MySQL随机更新数据的实际应用以及对MySQL随机查询数据、MySQL随机更新数据的实际应用代码的描述,以下就是文章的主要内容描述,望你会有所收获。
    2010-06-06
  • SQL查询超时的设置方法(关于timeout的处理)

    SQL查询超时的设置方法(关于timeout的处理)

    为了优化OceanBase的query timeout设置方式,特调研MySQL关于timeout的处理,下面与大家分享下处理记录,感兴趣的朋友可以参考下哈
    2013-04-04
  • 忘记mysql数据库root用户密码重置方法[图文]

    忘记mysql数据库root用户密码重置方法[图文]

    忘记mysql数据库root用户密码重置方法,需要的朋友可以参考下。
    2011-11-11
  • MySQL学习第三天 Windows 64位操作系统下验证MySQL

    MySQL学习第三天 Windows 64位操作系统下验证MySQL

    MySQL学习第三天教大家如何在Windows 64位操作系统下验证MySQL,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • 深入解析MYSQL 常用数值函数和条件函数

    深入解析MYSQL 常用数值函数和条件函数

    这篇文章主要介绍了MYSQL 常用数值函数和条件函数,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-04-04
  • MySQL长字符截断的实现示例

    MySQL长字符截断的实现示例

    本文主要介绍了MySQL长字符截断的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • MySQL多表查询、事务与索引的实践与应用操作

    MySQL多表查询、事务与索引的实践与应用操作

    本文围绕MySQL数据库操作展开,通过构建部门与员工管理、餐饮业务相关的数据库表,并填充测试数据,系统地阐述了多表查询的多种方式,包括内连接、外连接和不同类型的子查询,同时介绍了事务的处理以及索引的创建、查询和删除操作,感兴趣的朋友一起看看吧
    2025-04-04
  • MySQL中MIN()函数的使用教程

    MySQL中MIN()函数的使用教程

    这篇文章主要介绍了MySQL中MIN()函数的使用教程,是MySQL入门学习中的基础知识,需要的朋友可以参考下
    2015-05-05
  • 详解mysql基本操作语句命令

    详解mysql基本操作语句命令

    本文介绍了 链接Mysql,以及增删改查等功能,需要的朋友可以参考
    2017-04-04
  • MySQL查询学习之基础查询操作

    MySQL查询学习之基础查询操作

    这篇文章主要给大家介绍了关于MySQL查询学习之基础查询操作的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05

最新评论