Тъй като SET IDENTITY_INSERT
е чувствителен към сесията, управлява се на ниво буфер, без да се съхранява някъде. Това означава, че не е необходимо да проверяваме IDENTITY_INSERT
състояние, тъй като никога не използваме тази ключова дума в текущата сесия.
За съжаление няма помощ за това.
Страхотен въпрос обаче :)
Източник:Тук
Актуализиране Може би има начини да направите това, които също се виждат в сайта, който дадох връзка, IMO, това е твърде много усилия, за да бъде полезен.
if
(select max(id) from MyTable) < (select max(id) from inserted)
--Then you may be inserting a record normally
BEGIN
set @I = 1 --SQL wants something to happen in the "IF" side of an IF/ELSE
END
ELSE --You definitely have IDENTITY_INSERT on. Done as ELSE instead of the other way around so that if there is no inserted table, it will run anyway
BEGIN
.... Code that shouldn't run with IDENTITY_INSERT on
END