IT俱乐部 MsSql 数据库使用之union、union all、各种join的用法区别解析

数据库使用之union、union all、各种join的用法区别解析

一、Union 和Union All

1、区别:

Union去重,而Union All不去重。

2、注意点:

1.被合并的每个SELECT语句的列数、数据类型要相同(一一对应)。

2.使用Union时,由于可去重性,可能导致数据丢失。

3.使用Union All时,由于不可去重性,可能含重复的记录。

3、具体举例

【union】

【union all】

二、Join关键字的区别

 1.left join和inner join区别

【长话短说】inner join(内连接)得到数据更少,直接剔除匹配不到的数据(剔除无关联ID的数据),inner join = join。

【例子】如下图所示,inner join不显示红框的数据,left join会显示

SELECT * FROM student s
LEFT JOIN score sc on s.id=sc.studentid

SELECT * FROM student s
INNER JOIN score sc on s.id=sc.studentid

【查询匹配失败的数据】

SELECT * FROM student s
LEFT JOIN score sc on s.id=sc.studentid
WHERE sc.id is null --查询从表ID为空的数据,就是联表匹配不到的数据

2.联表条件写法差异

--联表:只要满足关联关系,B.IsDeleted是什么则返回什么
SELECT * FROM TABLEA A
LEFT JOIN TABLEB B ON A.ID=B.EXID 

--联表不筛选:只要满足关联关系,B.IsDeleted≠0 则返回null
SELECT * FROM TABLEA A
LEFT JOIN TABLEB B ON A.ID=B.EXID AND B.IsDeleted=0

--联表且筛选:只要满足关联关系,B.IsDeleted≠0 则返回null,假如是null则被where过滤掉
SELECT * FROM TABLEA A
LEFT JOIN TABLEB B ON A.ID=B.EXID
WHERE B.IsDeleted=0

--【结论】数据返回多少关系是:第一种=第二种>第三种
-- 因为第二种是A左联筛选后的B表,左外保证A表完整性,和第一种一样
-- 第三种是连接后再筛选,剔除的数据可能包含A表的数据

三、Cross Join

计算所有表的笛卡尔积:

总结 

到此这篇关于数据库使用之union、union all、各种join的用法区别解析的文章就介绍到这了,更多相关union、union all、join用法区别内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/database/mssql/14775.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部