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

SQL Server 2008中新增功能:可以使用单个Insert命令插入多行

<div class=”codetitle”><a style=”CURSOR: pointer” data=”11118″ class=”copybut” id=”copybut11118″ onclick=”doCopy(‘code11118’)”> 代码如下:<div class=”codebody” id=”code11118″>
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’,
(‘DemoC’,’CCC’,
(‘DemoD’,’DDD’,
(‘DemoE’,’EEE’,GETDATE()) –(5 row(s) affected)

除了可以一次性插入多行,values还有更巧妙的用法,不使用永久表或临时表而表示一个结果集,而且不需要函数或表变量。看下面的例子: 
<div class=”codetitle”><a style=”CURSOR: pointer” data=”2832″ class=”copybut” id=”copybut2832″ onclick=”doCopy(‘code2832’)”> 代码如下:<div class=”codebody” id=”code2832″>
–this SQL is only for SQL Server 2008
select DName,DDate
from
(values
(‘DemoA’,GETDATE())
)
Demo_Values (DName,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语句。 本人来自 cnblogs 邀月 3w@live.cn

作者: dawei

【声明】:永州站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

为您推荐

联系我们

联系我们

0577-28828765

在线咨询: QQ交谈

邮箱: xwei067@foxmail.com

工作时间:周一至周五,9:00-17:30,节假日休息

返回顶部