SQL Server 2008中SQL增強之一:Values新用途

iSQlServer發表於2010-10-13

  SQL Server 2008中新增功能:可以使用單個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還有更巧妙的用法,不使用永久表或臨時表而表示一個結果集,而且不需要函式或表變數。看下面的例子: 

 

<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

--&gt--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
*/

注意該語句的最後一行定義了“源”名稱和列名,其中列名用於select語句。

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-675828/,如需轉載,請註明出處,否則將追究法律責任。

相關文章