为何Union All把相同的记录去除了?
Use tempdb;
Go
Create table [dbo].[a] (name varchar null);
Create table [dbo].[b] (name varchar null);
Create table [dbo].[c] (name varchar null);
Insert Into [dbo].[a] values ('a'),('b'),('c');
Insert Into [dbo].[b] values ('a'),('d'),('c');
Insert Into [dbo].[c] values ('a'),('e'),('f');
GO
Select name From dbo.a
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
)
Union All
Select name From dbo.b
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
)
Union All
Select name From dbo.c
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
)
Select name From dbo.a
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
)
Union All (
Select name From dbo.b
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
) )
Union All (
Select name From dbo.c
except (
Select name From dbo.a
Intersect
Select name From dbo.b
Intersect
Select name From dbo.c
))
StmtText
---------------------------------------------------------------------------------
[解决办法]
--Nested Loops(Left Anti Semi Join, OUTER REFERENCES:([Union1037]))
[解决办法]
--Sort(DISTINCT ORDER BY:([Union1037] ASC))
[解决办法]
[解决办法]
--Concatenation
[解决办法]
[解决办法]
--Nested Loops(Left Anti Semi Join, OUTER REFERENCES:([Union1020]))
[解决办法]
[解决办法]
[解决办法]
--Sort(DISTINCT ORDER BY:([Union1020] ASC))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Concatenation
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Nested Loops(Left Anti Semi Join, OUTER REFERENCES:([tempdb].[dbo].[a].[name]))
[解决办法]
[解决办法]
------解决方案--------------------
[解决办法]
[解决办法]
--Sort(DISTINCT ORDER BY:([tempdb].[dbo].[a].[name] ASC))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[a]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[c].[name]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[b].[name]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[a]), WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[a].[name]))
------解决方案--------------------
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[b]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[c]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[b]))
[解决办法]
[解决办法]
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[c].[name]))
[解决办法]
[解决办法]
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[b].[name]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[a]), WHERE:([Union1020] = [tempdb].[dbo].[a].[name]))
[解决办法]
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[b]))
[解决办法]
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[c]))
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[c]))
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[c].[name]))
[解决办法]
--Nested Loops(Left Semi Join, WHERE:([tempdb].[dbo].[a].[name] = [tempdb].[dbo].[b].[name]))
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[a]), WHERE:([Union1037] = [tempdb].[dbo].[a].[name]))
[解决办法]
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[b]))
[解决办法]
--Table Scan(OBJECT:([tempdb].[dbo].[c]))