我试图在插入语句后得到一个键值。 例子: 我有一个表的属性名称和id。Id是一个生成的值。

    INSERT INTO table (name) VALUES('bob');

现在我想在同一步骤中取回id。这是怎么做到的?

我们使用的是Microsoft SQL Server 2008。


当前回答

不需要单独的SELECT…

INSERT INTO table (name)
OUTPUT Inserted.ID
VALUES('bob');

这也适用于非identity列(比如guid)

其他回答

不需要单独的SELECT…

INSERT INTO table (name)
OUTPUT Inserted.ID
VALUES('bob');

这也适用于非identity列(比如guid)

实体框架执行类似于gbn的答案:

DECLARE @generated_keys table([Id] uniqueidentifier)

INSERT INTO Customers(FirstName)
OUTPUT inserted.CustomerID INTO @generated_keys
VALUES('bob');

SELECT t.[CustomerID]
FROM @generated_keys AS g 
   JOIN dbo.Customers AS t 
   ON g.Id = t.CustomerID
WHERE @@ROWCOUNT > 0

输出结果存储在临时表变量中,然后选择返回给客户端。你必须意识到这一点:

insert可以生成多行,因此变量可以保存多行,因此可以返回多个ID

我不知道为什么EF会将临时表内部连接回实际表(在什么情况下两者会不匹配)。

但英孚就是这么做的。

仅支持SQL Server 2008或更新版本。如果是2005年,那你就不走运了。

您可以将选择语句附加到插入语句。 整数myInt = 插入到表1 (FName)值('Fred');选择Scope_Identity (); 这将在执行标量时返回一个标识的值。

建议使用SCOPE_IDENTITY()来获取新的ID值,而不是使用“OUTPUT Inserted”。ID”

如果插入语句抛出异常,我将直接抛出它。而是“输出插入”。ID”将返回0,这可能与预期不同。

使用SCOPE_IDENTITY()获取新的ID值

INSERT INTO table (name) VALUES('bob');

SELECT SCOPE_IDENTITY()

http://msdn.microsoft.com/en-us/library/ms190315.aspx