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

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

posted @   邀月  阅读(10248)  评论(18编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
历史上的今天:
2009-10-12 程序物语(二):起手式
点击右上角即可分享
微信分享提示