tsql – 在INSERT之后使用OUTPUT将identity列的值赋值为(非表值)变量

给出以下简单测试表:
CREATE TABLE dbo.Test
(
  Id bigint IDENTITY(1,1) NOT NULL,Name varchar(50) NULL
)

我想使用OUTPUT子句在INSERT之后将标识列的值获取为标量变量,但这不起作用:

DECLARE @InsertedId BIGINT;

INSERT INTO Test(Name) 
  OUTPUT @InsertedId=inserted.Id
  VALUES ('Michael')

-- Display resulting id for debugging
SELECT @InsertedId;
-- ...

我知道我可以在INSERT之后使用SCOPE_IDENTITY()轻松地执行此操作,但是可以使用OUTPUT子句作为INSERT语句的一部分而不使用表变量吗?

更新,另一个也是不合法的尝试:

-- Return the id as a result set
INSERT INTO Test(Name) 
OUTPUT inserted.Id AS TheId
VALUES ('Michael')

-- But you can't use the result set as a derived table...
SELECT TheId FROM
(
  INSERT INTO Test(Name) 
  OUTPUT inserted.Id AS TheId
  VALUES ('Michael')
)

-- ...,or you would be able to do this
SELECT TOP 1 @InsertedId=TheId
FROM
(
  INSERT INTO Test(Name) 
  OUTPUT inserted.Id AS TheId
  VALUES ('Michael')
)

解决方法

记住输出子句的值是它可以返回多个记录和多个字段.因此,您可以输出一组数据的自然键和标识,因此您还可以使用集合理论将多个记录插入到子表中.输出非常强大,它将付出代价来习惯使用它.

目前,在Microsoft不打算修复的scope_identity()(见链接http://connect.microsoft.com/SQLServer/feedback/details/328811/scope-identity-sometimes-returns-incorrect-value)中有一个错误.这应该给你一个线索,即是否应该使用输出来进行新的开发,即使它对于单个记录来说有点肮脏.

相关文章

(一)日志传送架构 (1.1)相关服务器 主服务器 :用于生产的服务器,上面运行这生产SQL Server数据库...
(一)事故背景 最近在SQL Server 2012生产数据库上配置完事物复制(发布订阅)后,生产数据库业务出现了...
(一)测试目的 目前公司使用的SQL SERVER 2012高可用环境为主备模式,其中主库可执行读写操作,备库既...
(一)背景个人在使用sql server时,用到了sql server的发布订阅来做主从同步,类似MySQL的异步复制。在...
UNION和OR谓词 找出 product 和 product2 中售价高于 500 的商品的基本信息. select * from product wh...
datawhale组队学习task03