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语句。 
本人来自 cnblogs 邀月 3w@live.cnSQLServer 2008中SQL增强之一:Values新用途
原文:http://www.jb51.net/article/27088.htm