在SQL Server中,执行插入时是否可以获取记录的“id”?
-
09-06-2019 - |
题
在 SQL Server 2005 中,我的表中有一个“id”字段,该字段的“Is Identity”属性设置为“Yes”。因此,当在该表上执行插入时,“id”会自动设置为下一个递增整数。执行插入时是否有一种简单的方法来获取“id”设置的内容,而不必在插入后立即执行 Select 语句?
重复:
获取插入行标识的最佳方法?
解决方案
至少在.Net 中,您可以一次性向服务器发送多个查询。我在我的应用程序中执行此操作:
command.CommandText = "INSERT INTO [Employee] (Name) VALUES (@Name); SELECT SCOPE_IDENTITY()";
int id = (int)command.ExecuteScalar();
奇迹般有效。
其他提示
如果要插入多行,则使用 OUTPUT
和 INSERTED.columnname
条款关于 insert
语句是将所有 id 放入临时表的简单方法。
DECLARE @MyTableVar table( ID int,
Name varchar(50),
ModifiedDate datetime);
INSERT MyTable
OUTPUT INSERTED.ID, INSERTED.Name, INSERTED.ModifiedDate INTO @MyTableVar
SELECT someName, GetDate() from SomeTable
Scope_identity() 是首选方式,请参阅: 获取当前身份值的 6 种不同方法
范围_身份();是你最好的选择。如果您使用 .NET,只需传递我们的参数并在程序运行后检查该值。
CREATE PROCEDURE [dbo].[InsertProducts]
@id INT = NULL OUT,
@name VARCHAR(150) = NULL,
@desc VARCHAR(250) = NULL
AS
INSERT INTO dbo.Products
(Name,
Description)
VALUES
(@name,
@desc)
SET @id = SCOPE_IDENTITY();
您必须选择scope_identity() 函数。
为了从应用程序代码中执行此操作,我通常将此过程封装在一个存储过程中,因此它看起来仍然像对我的应用程序的一个查询。
我倾向于使用企业管理器将触发器附加到表中。这样您就不必担心在代码中编写额外的 sql 语句。我的看起来像这样:
在dbo.tblname上为insert创建触发tblname,为select new_id = @@ endentity
然后,在代码中,将插入语句视为选择语句 - 只需执行并评估结果即可。“newID”列将包含您刚刚创建的行的标识。
这可能是我为 SQL Server 找到的最好的工作解决方案。SQL Server 在插入语句后返回标识列的值
不隶属于 StackOverflow