SQL 2008 values

本文介绍了 SQL Server 2008 中的一项新增功能,即使用单个 Insert 命令可以一次性插入多行数据。通过示例展示了如何在不使用永久表或临时表的情况下表示一个结果集,并说明了 values 子句的巧妙用法。

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

Create table Demo_Values(
    PKID int not null identity(11primary key   
    ,DName Nvarchar(20null   
    ,DCode NVarchar(30null   
    ,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)     
drop table Demo_Values   

--除了可以一次性插入多行,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        2012-04-20 08:02:03.930
--
DemoB        BBB        2012-04-20 08:02:03.930
--
DemoC        CCC        2012-04-20 08:02:03.930
--
DemoD        DDD        2012-04-20 08:02:03.930
--
DemoE        EEE        2012-04-20 08:02:03.930 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值