SQL server 误区学习之Union和Union all

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个结果集合相加,除去结果集中重复的记录后剩下不重复的记录。

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值