SQLServer 2008中SQL增強(qiáng)之一:Values新用途

SQL Server 2008中新增功能:可以使用單個(gè)Insert命令插入多行

代碼如下:
Create table Demo_Values
(PKID int not null identity(1,1) primary key
,DName Nvarchar(20) null
,DCode NVarchar(30) null
,DDate datetime null
)
go

–this SQL is only for SQL Server 2008
Insert into Demo_Values
(DName,DCode,DDate)
values
(‘DemoA’,’AAA’,GETDATE()),
(‘DemoB’,’BBB’,GETDATE()),
(‘DemoC’,’CCC’,GETDATE()),
(‘DemoD’,’DDD’,GETDATE()),
(‘DemoE’,’EEE’,GETDATE())

–(5 row(s) affected)

除了可以一次性插入多行,values還有更巧妙的用法,不使用永久表或臨時(shí)表而表示一個(gè)結(jié)果集,而且不需要函數(shù)或表變量。看下面的例子: 
代碼如下:
–this SQL is only for SQL Server 2008
select DName,DCode,DDate
from
(values
(‘DemoA’,’AAA’,GETDATE()),
(‘DemoB’,’BBB’,GETDATE()),
(‘DemoC’,’CCC’,GETDATE()),
(‘DemoD’,’DDD’,GETDATE()),
(‘DemoE’,’EEE’,GETDATE())
)
Demo_Values (DName,DCode,DDate)
–(5 row(s) affected)

/*
DName DCode DDate
DemoA AAA 2010-10-12 20:37:45.500
DemoB BBB 2010-10-12 20:37:45.500
DemoC CCC 2010-10-12 20:37:45.500
DemoD DDD 2010-10-12 20:37:45.500
DemoE EEE 2010-10-12 20:37:45.500
*/

注意該語(yǔ)句的最后一行定義了“源”名稱和列名,其中列名用于select語(yǔ)句。

本人來(lái)自 cnblogs 邀月 3w@live.cn

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊14 分享