Od SET IDENTITY_INSERT
jest wrażliwy na sesję, jest zarządzany na poziomie bufora bez przechowywania gdzieś. Oznacza to, że nie musimy sprawdzać IDENTITY_INSERT
status, ponieważ nigdy nie używamy tego słowa kluczowego w bieżącej sesji.
Przepraszamy, nie ma w tym pomocy.
Świetne pytanie :)
Źródło:tutaj
Aktualizacja Być może są sposoby, aby to zrobić, również w witrynie, do której połączyłem, IMO, to zbyt duży wysiłek, aby być użytecznym.
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