站长之家 - 网站建设 - 数据库 - Sqlserver2008 - SQLServer 2008中SQL增强之一:Values新用途

SQLServer 2008中SQL增强之一:Values新用途

2016-06-23   来源:中国站长之家网友   网络编辑:www.zzvips.com   查看评论
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
(/#39;DemoA/#39;,/#39;AAA/#39;,GETDATE()),
(/#39;DemoB/#39;,/#39;BBB/#39;,GETDATE()),
(/#39;DemoC/#39;,/#39;CCC/#39;,GETDATE()),
(/#39;DemoD/#39;,/#39;DDD/#39;,GETDATE()),
(/#39;DemoE/#39;,/#39;EEE/#39;,GETDATE())

--(5 row(s) affected)

除了可以一次性插入多行,values还有更巧妙的用法,不使用永久表或临时表而表示一个结果集,而且不需要函数或表变量。看下面的例子: 
复制代码 代码如下:

--this SQL is only for SQL Server 2008
select DName,DCode,DDate
from
(values
(/#39;DemoA/#39;,/#39;AAA/#39;,GETDATE()),
(/#39;DemoB/#39;,/#39;BBB/#39;,GETDATE()),
(/#39;DemoC/#39;,/#39;CCC/#39;,GETDATE()),
(/#39;DemoD/#39;,/#39;DDD/#39;,GETDATE()),
(/#39;DemoE/#39;,/#39;EEE/#39;,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
*/

注意该语句的最后一行定义了/ldquo;源/rdquo;名称和列名,其中列名用于select语句。

本人来自 cnblogs 邀月 3w@live.cn

热门搜索
最新 | 排行
热门"Sqlserver2008"