您的位置:首页 > 数据库

SQL server 误区学习之Union和Union all

2013-01-12 14:27 453 查看
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个结果集合相加,除去结果集中重复的记录后剩下不重复的记录。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: