SQL的连接JOIN中 on 与 where 的区别

一、结论 - on和where的区别

数据库在通过连接两张或多张表来返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户。

在使用 left join 时,onwhere 条件的区别如下:

  • 1、 on 条件是在生成临时表时使用的条件,它不管 on 中的条件是否为真,都会返回左边表中的记录。
  • 2、where 条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有 left join 的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。

二、举例解释

假设有两张表:
表1:tab1

idsize
110
220
330

表2:tab2

sizename
10AAA
20BBB
20CCC

两条 SQL:

select * from tab1 left join tab2 on (tab1.size = tab2.size) where tab2.name='AAA'

select * from tab1 left join tab2 on (tab1.size = tab2.size and tab2.name='AAA')

在这里插入图片描述
在这里插入图片描述
详细解释第二条sql为什么返回的不是4条而是3条?
这条查询语句使用了左连接(left join),它会返回左表(tab1)中的所有记录,以及右表(tab2)中与左表匹配的记录。连接条件是 tab1.size = tab2.size and tab2.name=‘AAA’,也就是说,只有在 tab2.name 为 ‘AAA’ 且 tab1.size 等于 tab2.size 的情况下,才会将两表的记录连接起来。

现在我们来分析具体的连接过程:

  • tab1.id = 1, tab1.size = 10

在 tab2 中查找 size = 10 且 name = ‘AAA’ 的记录:存在一条符合条件的记录。
结果集中会包括 tab1.id = 1 对应的这条记录。

  • tab1.id = 2, tab1.size = 20

在 tab2 中查找 size = 20 且 name = ‘AAA’ 的记录:这里并没有符合条件的记录。
因为是左连接,所以即使在 tab2 中没有符合条件的记录,也会返回 tab1 的这条记录。
结果集中会包括 tab1.id = 2 对应的这条记录。

  • tab1.id = 3, tab1.size = 30

在 tab2 中查找 size = 30 且 name = ‘AAA’ 的记录:这里也没有符合条件的记录。
同样因为是左连接,会返回 tab1 的这条记录。
结果集中会包括 tab1.id = 3 对应的这条记录。

因此,根据左连接的性质以及连接条件 tab2.name = ‘AAA’,最终的结果集中只会包括满足条件的记录和左表中没有匹配的记录。在这个例子中,只有 tab2 中 size = 10 且 name = ‘AAA’ 的记录满足条件,因此结果集中只会返回 3 条记录。

所以,这就解释了为什么查询语句 select * from tab1 left join tab2 on (tab1.size = tab2.size and tab2.name=‘AAA’) 返回了 3 条记录而不是 4 条记录。

三、总结

其实以上结果的关键原因就是 left join、right join、full join 的特殊性,不管 on 上的条件是否为真都会返回 left 或 right 表中的记录,full 则具有 left 和 right 的特性的并集。 而 inner jion 没这个特殊性,则条件放在 on 中和 where 中,返回的结果集是相同的

select * from tab1 INNER  join tab2 on tab1.size = tab2.size WHERE tab2.name='AAA'
select * from tab1 INNER  join tab2 on tab1.size = tab2.size and tab2.name='AAA'

inner jion返回的是相同的
在这里插入图片描述

  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农小C

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值