SQL基础知识:join操作后面的on与where的区别

导读:本篇文章讲解 SQL基础知识:join操作后面的on与where的区别,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

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

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

假设有两张表:
SQL基础知识:join操作后面的on与where的区别

两条 SQL:

selectform tabl left join tab2 on(tabl.size=tab2.size)where tab2.name='AAA'


selectform tabl left join tab2 on(tabl.size=tab2.size and tab2.name='AAA)

第一条SQL的过程:
1、中间表on条件;
SQL基础知识:join操作后面的on与where的区别
2、再对中间表过滤where条件:tab2.name=AAA’tab1.id tab1.size tab2.size tab2.name
SQL基础知识:join操作后面的on与where的区别

第二条SQL的过程:
1、中间表on条件:tabl.size=tab2.size and tab2.name=’AAA’(条
件不为真也会返回左表中的记录)
SQL基础知识:join操作后面的on与where的区别

===============================================

示例二:

group查询,不增加指定用户限定 dict.gmt_creator = ‘32255’ 

SELECT
	region.region_id,
	region.region_name,
	region.gmt_creator AS table1_gmt_creator,
	table2_gmt_creator 
FROM
	(
	SELECT
		agg.*,
		dict.type AS type,
		dict.gmt_creator AS table2_gmt_creator 
	FROM
		monitor_region_agg agg
		LEFT JOIN monitor_dict dict ON agg.region_id = dict.region_id 
		AND agg.is_delete = '0' 
		AND dict.type IN ( 'attention', 'readStatus' ) 
	WHERE
		1 = 1 
		AND agg.tenant_code = '00000007' 
		AND agg.business_code = '005' 
		AND agg.app_code = '005' 
	) region
	LEFT JOIN monitor_region_person_relation person ON region.region_id = person.region_id 
WHERE
	region.`is_delete` = '0' 
	AND person.`is_delete` = '0' 
	AND person.gather_flag = '0' 
	AND region.tenant_code = '00000007' 
	AND region.business_code = '005' 
	AND region.app_code = '005' 
	AND region.risk_date >= '2020-10-20' 
	AND region.risk_date <= '2021-01-20' 
GROUP BY
	region.region_id

结果:

SQL基础知识:join操作后面的on与where的区别

二、group查询,增加指定用户限定 dict.gmt_creator = ‘32255’ 

SELECT
	region.region_id,
	region.region_name,
	region.gmt_creator AS table1_gmt_creator,
	table2_gmt_creator 
FROM
	(
	SELECT
		agg.*,
		dict.type AS type,
		dict.gmt_creator AS table2_gmt_creator 
	FROM
		monitor_region_agg agg
		LEFT JOIN monitor_dict dict ON agg.region_id = dict.region_id 
		AND agg.is_delete = '0' 
		AND dict.type IN ( 'attention', 'readStatus' ) 
		AND dict.gmt_creator = '32255' 
	WHERE
		1 = 1 
		AND agg.tenant_code = '00000007' 
		AND agg.business_code = '005' 
		AND agg.app_code = '005' 
	) region
	LEFT JOIN monitor_region_person_relation person ON region.region_id = person.region_id 
WHERE
	region.`is_delete` = '0' 
	AND person.`is_delete` = '0' 
	AND person.gather_flag = '0' 
	AND region.tenant_code = '00000007' 
	AND region.business_code = '005' 
	AND region.app_code = '005' 
	AND region.risk_date >= '2020-10-20' 
	AND region.risk_date <= '2021-01-20' 
GROUP BY
	region.region_id

结果:

SQL基础知识:join操作后面的on与where的区别

 

其实以上结果的关键原因

left join,right join,full join 的特殊性,不管on上的条件是否为真都会返回1eft或right表中的记录,ful1则具有left和right的特性的并集。

而inner join 没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

on为了反映外连接中一方的全连接,而where没有这个功能,内连接配对是可以的。

 

结论
1.where 是在两个表join完成后,再附上where条件

2.而 and 则是在表连接前过滤A表或B表里面哪些记录符合连接条件,同时会兼顾是left join还是right join。

即假如是左连接的话,如果左边表的某条记录不符合连接条件,那么它不进行连接,但是仍然留在结果集中(此时右边部分的连接结果为NULL)。on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。

3.而inner join 没这个特殊性,则条件放在on中和where中,返回的结果集是相同的。

4.建议尽量用where来过滤条件。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/13966.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!