我试图在插入语句后得到一个键值。 例子: 我有一个表的属性名称和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。
当前回答
你可以使用scope_identity()选择刚刚插入变量的行ID然后从表中选择你想要的任何列其中ID =你从scope_identity()中得到的标识
请在这里查看MSDN信息http://msdn.microsoft.com/en-us/library/ms190315.aspx
其他回答
@@IDENTITY是一个系统函数,返回最后插入的标识值。
你可以使用scope_identity()选择刚刚插入变量的行ID然后从表中选择你想要的任何列其中ID =你从scope_identity()中得到的标识
请在这里查看MSDN信息http://msdn.microsoft.com/en-us/library/ms190315.aspx
*参数在连接字符串中的顺序有时很重要。* Provider参数的位置可以在添加一行后中断记录集游标。我们在SQLOLEDB提供程序中看到了这种行为。
添加行之后,行字段不可用,除非Provider被指定为连接字符串中的第一个参数。当提供程序位于连接字符串中的任何位置(除了第一个参数之外)时,新插入的行字段将不可用。当我们将提供者移动到第一个参数时,行字段神奇地出现了。
不需要单独的SELECT…
INSERT INTO table (name)
OUTPUT Inserted.ID
VALUES('bob');
这也适用于非identity列(比如guid)
最好和最可靠的解决方案是使用SCOPE_IDENTITY()。
你只需要在每次插入后获取作用域标识并将其保存在一个变量中,因为你可以在同一个作用域中调用两个插入。
Ident_current和@@identity可能是他们工作,但他们不是安全范围。在大型应用程序中可能会出现问题
declare @duplicataId int
select @duplicataId = (SELECT SCOPE_IDENTITY())
更多细节在这里微软文档