我是靠谱客的博主 谦让山水,最近开发中收集的这篇文章主要介绍SQL Server 中的并集、交集、差集的操作,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、有时我们要对两个表的相同字段的值进行合并,这是我们可以对结果集进行并集操作

2、有时我们要找出两个表的相同字段 相同的值,这是我们可以对结果集进行交集操作

3、有时我们要找出两个表的相同字段 存在差异的值,这是我们可以对结果集进行差集操作

 

下面是并集、交集、差集的操作

1、首先我们先建测试表、再插入测试数据

drop table if exists test_01
create table test_01(tID int,name varchar(10),sex varchar(10));

drop table if exists test_02
create table test_02(tID int,name varchar(10),sex varchar(10));

insert into test_01 values('1','Dina','女');
insert into test_01 values('2','Aaron ','男');
insert into test_01 values('3','Jane','女');
insert into test_01 values('4','Joyce','女');
insert into test_01 values('5','Mandy','女');
 
insert into test_02 values('1','Joyce','女');
insert into test_02 values('2','Davis','男');
insert into test_02 values('3','Dina','女');

2、查看我们的数据

 

3、将表test_01和表test_02 中的 name 合并(去掉重复值)

select name from test_01
union 
select name from test_02

 4、将表test_01和表test_02 中的 name 合并(不去掉重复值) 

select name from test_01
union all
select name from test_02

 

 5、查找表test_01和表test_02 中的 name 列相同的值

select name from test_01
intersect
select name from test_02

6、查找 name 列中在表test_01中有而在表test_02 中没有的值

select name from test_01
except
select name from test_02

 7、查找 name 列中在表test_02中有而在表test_01 中没有的值

select name from test_02
except
select name from test_01

希望对你有帮助!!

最后

以上就是谦让山水为你收集整理的SQL Server 中的并集、交集、差集的操作的全部内容,希望文章能够帮你解决SQL Server 中的并集、交集、差集的操作所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(49)

评论列表共有 0 条评论

立即
投稿
返回
顶部