Union和Union all 大家都知道是什么,也知道它们之间的区别,以例子来说,
建表语句: CREATE TABLE [dbo].[excel_read]
(
[id] [int] NULL,
[name] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO
INSERT INTO dbo.excel_read ( id, name )VALUES ( 1, N'Excel' )
INSERT INTO dbo.excel_read( id, name )VALUES ( 2, N'Sqlserver2008' )
现在运行语句:
select id,name from excel_read a
union all
select id,name from excel_read b
和
select id,name from excel_read a
union
select id,name from excel_read b
现在向excel_read 插入2次重复数据
insert into excel_read(id,name)
select id,name from excel_read
insert into excel_read(id,name)
select id,name from excel_read
现在excel_read有8条数据,
在执行下面的语句:
select id,name from excel_read a
union all
select id,name from excel_read b
和
select id,name from excel_read a
union
select id,name from excel_read b
大家可以猜下两条语句结果。
union all 是a+b一共16条记录,2个结果集合相加,不去除重复记录
union 是2条记录,2个结果集合相加,除去结果集中重复的记录后剩下不重复的记录。