Ken*_*130 8 t-sql sql-server stored-procedures
我有一个存储过程,首先将一些数据插入临时表,然后将行插入另一个表.我在第二次插入后调用Scope_Identity()来获取新插入的记录Identity.
如果第二个插入由于连接而没有做任何事情,我想检查Scope_Identity并引发异常.但Scope_Identity返回在第二次插入之前从临时表插入创建的最后一个标识.
有没有办法在调用第二个插入之前重置SCOPE_IDENTITY,或者更好的方法来确定第二个插入是否实际上没有插入任何内容?
Mar*_*ith 11
第二次插入后@@ROWCOUNT 立即检查.如果为0则不插入任何行.
INSERT INTO YourTable
SELECT ...
IF (@@ROWCOUNT = 0)
BEGIN
RAISERROR('Nothing inserted',16,1)
RETURN
END
Run Code Online (Sandbox Code Playgroud)
@Martin Smith完全回答了你的问题(我赞成他).
这显然是互联网上唯一一个询问如何重置Scope_Identity()的页面.
我相信这对于使用T-SQL的人来说至关重要.
我将这个答案留给那些来到这里(像我一样)寻找前一个插入语句插入的身份(而不是最后一个随机成功的身份插入)的人.
这就是我想出的:
SET @SomeID = (CASE WHEN @@ROWCOUNT > 0 THEN SCOPE_IDENTITY() ELSE NULL END)
Run Code Online (Sandbox Code Playgroud)