我试图在插入语句后得到一个键值。 例子: 我有一个表的属性名称和id。Id是一个生成的值。
INSERT INTO table (name) VALUES('bob');
现在我想在同一步骤中取回id。这是怎么做到的?
我们使用的是Microsoft SQL Server 2008。
我试图在插入语句后得到一个键值。 例子: 我有一个表的属性名称和id。Id是一个生成的值。
INSERT INTO table (name) VALUES('bob');
现在我想在同一步骤中取回id。这是怎么做到的?
我们使用的是Microsoft SQL Server 2008。
当前回答
实体框架执行类似于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年,那你就不走运了。
其他回答
你可以使用scope_identity()选择刚刚插入变量的行ID然后从表中选择你想要的任何列其中ID =你从scope_identity()中得到的标识
请在这里查看MSDN信息http://msdn.microsoft.com/en-us/library/ms190315.aspx
*参数在连接字符串中的顺序有时很重要。* Provider参数的位置可以在添加一行后中断记录集游标。我们在SQLOLEDB提供程序中看到了这种行为。
添加行之后,行字段不可用,除非Provider被指定为连接字符串中的第一个参数。当提供程序位于连接字符串中的任何位置(除了第一个参数之外)时,新插入的行字段将不可用。当我们将提供者移动到第一个参数时,行字段神奇地出现了。
在插入一个带有identity列的表之后,你可以引用@@IDENTITY来获取值: http://msdn.microsoft.com/en-us/library/aa933167%28v=sql.80%29.aspx
您可以将选择语句附加到插入语句。 整数myInt = 插入到表1 (FName)值('Fred');选择Scope_Identity (); 这将在执行标量时返回一个标识的值。
实体框架执行类似于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年,那你就不走运了。