DECLARE @A table (col1 int)
insert into @A select 1
insert into @A select 1
insert into @A select 2
insert into @A select 3
insert into @A select 4
insert into @A select 4
insert into @A select 5
insert into @A select null
insert into @A select null
DECLARE @B table (col2 int)
insert into @B select null
insert into @B select 1
insert into @B select 2
insert into @B select 3
DECLARE @C table (col3 int)
insert into @C select 1
insert into @C select 5
insert into @C select 6
--EXCEPT
--SELECT col3 FROM @c
--INTERSECT
EXCEPT
SELECT col2 FROM B
INTERSECT --优先执行
SELECT col3 FROM C
insert into @A select 1
insert into @A select 1
insert into @A select 2
insert into @A select 3
insert into @A select 4
insert into @A select 4
insert into @A select 5
insert into @A select null
insert into @A select null
DECLARE @B table (col2 int)
insert into @B select null
insert into @B select 1
insert into @B select 2
insert into @B select 3
DECLARE @C table (col3 int)
insert into @C select 1
insert into @C select 5
insert into @C select 6
--找出A表的col1列不存在c表col1列的所有非重复值
--SELECT col1 FROM @A--EXCEPT
--SELECT col3 FROM @c
--找出A表的col1列存在c表col1列的所有非重复值
--INTERSECT
--SELECT col3 FROM @c
-- 1,找出B表的col1列存在B表col1列的所有非重复值
--2,找出A表的col1列不存在1比对列的所有非重复值
SELECT col1 FROM AEXCEPT
SELECT col2 FROM B
INTERSECT --优先执行
SELECT col3 FROM C
本文通过具体的SQL语句示例,展示了如何使用EXCEPT和INTERSECT操作来找出不同表间的数据关系,包括如何找出一个表中相对于另一个表存在的非重复值。
1383

被折叠的 条评论
为什么被折叠?



