继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

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

郎朗坤
关注TA
已关注
手记 334
粉丝 48
获赞 212

 SQL Server 2008中SQL应用系列--目录索引


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还有更巧妙的用法,不使用永久表或临时表而表示一个结果集,而且不需要函数或表变量。看下面的例子: 

复制代码

--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语句。

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP