. 摘要

关于这两种写法的重要知识点摘要如下:

  1. left-join 时,即使有相同的查询条件,二者的查询结果集也不同,原因是优先级导致的,on 的优先级比 where 高
  2. on-and 是进行韦恩运算连接生成临时表时使用的条件
  3. where 是全部连接完生成临时表后,再根据条件过滤
  4. on 优先级比 where 高,因此,理论上 on-and 写法执行效率比 on-where 高,速度更快
  5. inner-join 时,不管是对左表还是右表进行筛选,on-and 和 on-where 都会对生成的临时表进行过滤

2. 这两种写法有什么区别

两者放置相同条件,之所以可能会导致结果集不同,就是因为优先级。on的优先级是高于where的。

首先明确两个概念:

  • left join 关键字会从左表 (tb_user) 那里返回所有的行,即使在右表 (tb_score) 中没有匹配的行。
  • 数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。

在left join下,两者的区别:

  • on是在生成临时表的时候使用的条件,不管on的条件是否起到作用,都会返回左表 (tb_user) 的行。
  • where则是在生成临时表之后使用的条件,此时已经不管是否使用了left join了,只要条件不为真的行,全部过滤掉。

在多表查询时,on 比 where 更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再由 where 进行过滤,然后再计算,计算完后再由 having 进行过滤。由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里。

对于 join 参与的表的关联操作,如果需要不满足连接条件的行也在我们的查询范围内的话,我们就必需把连接条件放在 on 后面,而不能放在 where 后面,如果我们把连接条件放在了 where 后面,那么所有的left , right 等这些操作将不起任何作用,对于这种情况,它的效果就完全等同于 inner 连接。对于那些不影响选择行的条件,放在 on 或者 where 后面就可以。

记住:所有的连接条件都必需要放在 on 后面,不然前面的所有 left,right 关联将作为摆设,而不起任何作用。

3. 实例演示

第一步:新建2张表并插入数据

新建2张表:用户表(tb_user)、用户得分表(tb_score)

表 tb_user 和 tb_score 数据

第二步:执行查询语句

(1)执行 left-join-on-and 写法SQL

select u.name,u.age,s.score
from tb_user uleft join tb_score s on s.user_id=u.id and s.score<90
where u.age>20;

执行结果:

(2)执行 left-join-on-where 写法SQL

select u.name,u.age,s.score
from tb_user uleft join tb_score s on s.user_id=u.id
where u.age>20
and s.score<90;

执行结果:

第一个sql的执行流程:首先找到 s 表的 score 小于90 的记录行(on s.user_id=u.id and s.score<90),然后找到 u 的数据(即使不符合 s 表的规则),生成临时表返回用户。

第二个sql的执行流程:首先生成临时表,然后执行 where 过滤 on s.score<90 不为真的结果集,最后返回给用户。

因为on会首先过滤掉不符合条件的行,然后才会进行其它运算,所以按理说on是最快的。

第三步:分析执行过程及结果

根据执行过程,从上述执行结果可以看出:

  1. 这2个SQL语句的执行结果完全不同,使用时需要注意
  2. 两者放置相同条件,之所以可能会导致结果集不同,就是因为优先级:on的优先级是高于where的
  3. 写法 left-join-on-and 在连表查询过程中先根据 on-and 条件过滤右表(即 tb_score 表),再执行 join 操作生成临时表,然后对临时表执行 where 条件,因此,on-and 写法会先对右表同时做2个条件( s.user_id=u.id and s.score<90)的过滤
  4. 写法 left-join-on-where 在连表查询过程中先根据 on 条件过滤右表,再执行 join 操作生成临时表,然后对临时表执行 where 条件, 因此,on-where 写法会先对右表做1个条件( s.score<9 )的过滤,然后对 join 后的结果再执行1个条件的过滤
  5. 由于 on 优先级比 where 更高,执行时机会更早,因此,理论上来说 on-and 写法比 on-where 写法效率更高、执行更快

left join-on-and 与 left join-on-where相关推荐

  1. java fork join原理_细说Fork/Join框架

    什么是Fork/Join框架? Fork/Join框架是JDK1.7提供的一个用于并行执行任务的框架,是一个把大任务分割成若干小任务,最终汇总每个小任务结果后得到大任务结果的框架.Fork就是把一个大 ...

  2. mysql right join实例_MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程

    LEFT JOIN 语法用法与实例MySQL LEFT JOIN 语法 SQL(MySQL) LEFT JOIN 会取得左表(table1)全部记录,即使右表(table2)并无对应匹配记录.LEFT ...

  3. 【Transact-SQL】SQL Server自动把left join自动转化为inner join、以及关联时的数据重复问题...

    1.SQL Server自动把left join自动转化为inner join的问题: 下面的两个语句都是left join的,但是一个却转化成了 inner join drop table a,B ...

  4. Python中join()方法和os.path.join()方法

    join() 方法: 描述:join()方法用于将序列中的元素以指定的字符连接成一个新的字符串 语法:x.join(y) y: 可迭代对象,对象内的元素必须是字符串类型.对象可以是字符串.元组.列表和 ...

  5. Mysql 优化器内部JOIN算法hash join Nestloopjoin及classic hash join CHJ过程详解

    Mysql hash join之classic hash join CHJ过程详解 hash join的历史 优化器里的hash join算法在SQL Server.Oracle.postgress等 ...

  6. mysql连接方式左联_数据库中的左连接(left join)和右连接(right join)区别 | 改变自己...

    Left Join / Right Join /inner join相关 关于左连接和右连接总结性的一句话: 左连接where只影向右表,右连接where只影响左表. Left Join select ...

  7. mysql join 与 cross join 效率_浅析Mysql Join语法以及性能优化

    在讲MySQL的Join语法前还是先回顾一下联结的语法,呵呵,其实连我自己都忘得差不多了,那就大家一起温习吧,这里我有个比较简便的记忆方法,内外联结的区别是内联结将去除所有不符合条件的记录,而外联结则 ...

  8. mysql+join的原理,Mysql连接join查询原理知识点

    Mysql连接join查询原理知识点 Mysql连接(join)查询 1.基本概念 将两个表的每一行,以"两两横向对接"的方式,所得到的所有行的结果. 假设: 表A有n1行,m1列 ...

  9. Hive中的map join、left semi join和sort merge bucket join

    map join map join是将join双方比较小的表直接分发到各个 map进程的内存中,在map进程中进行join操作,这样就不用进行reduce步骤,从而提高了速度. 如果不指定mapjoi ...

  10. 1.19.5.4.流上的Join、常规Join、时间区间Join、时态表Join、基于处理时间的时态Join、时态表函数Join、用法

    1.19.5.4.流上的Join 1.19.5.4.1.常规Join 1.19.5.4.2.时间区间Join 1.19.5.4.3.时态表Join 1.19.5.4.4.基于处理时间的时态Join 1 ...

最新文章

  1. NET Framework 2.0中的数据访问新特性
  2. 一文带你了解为什么是知识图谱的时代!
  3. 提高方面级情感分析的性能:一种结合词汇图和句法图的方法
  4. TortoiseGit上传代码报错error:1407742E
  5. Android彻底组件化方案实践
  6. Android 编码规范:(五)避免创建不必要的对象
  7. iPhoneアプリに本格ホラーアドベンチャー監獄脱出少女 android
  8. 前端复习笔记(一)——HTML
  9. CC***原理及防范方法
  10. 上海电信光猫SA1456C桥接后4K IPTV继续使用
  11. php与阿里云短信接口接入
  12. 家长如何使自己的孩子轻松快乐地学好数学和英语?
  13. ppt文件太大怎么变小?
  14. 得空写的基于web的工作流表单设计器,大家看看怎么样
  15. Django微信抢票大作业总结
  16. 夕阳红旅游团第四周报告
  17. 我糟糕的2019年:虽流年不利,但我心仍坚定
  18. 张震讲鬼故事MP3全集
  19. Games101 计算机图形学课程笔记: Lecture 08 Shading 2 (Shading, Pipeline and Texture Mapping)
  20. 怎样实现随机抽题php,ppt VBA 实现随机抽题

热门文章

  1. 标签超出图像控件c语言,VC++标签控件之图像标签控件
  2. 如何免费识别图片文字?这几个软件彻底解放你的双手
  3. 华为鸿蒙麒麟玉兔_华为注册了整本《山海经》的商标?“鸿蒙”操作系统成功申请...
  4. python字母对应序号_python获取字母在字母表对应位置的几种方法及性能对比较
  5. 项目环境搭建-logback.xml常用配置
  6. 配F-RCN遇到的问题(hdf5.h: 没有那个文件或目录)及解决
  7. 蓦然回首,十余年的程序员生涯最后就只剩下了这些!希望我犯过的错误你不要再犯!
  8. DSSD : Deconvolutional Single Shot Detector论文阅读笔记
  9. 卷积神经网络 图像识别,卷积神经网络处理图片
  10. Windows11打开任务管理器的方式