Edit:
Потратив несколько часов на сравнение целых дампов страниц, я понял, что есть более простой способ, и мне следует остаться на DMV.
Значение сохраняется при резервном копировании / восстановлении, что является четким признаком того, что оно сохранено - я сбросил все страницы в БД и не смог найти расположение / изменение для того времени
запись была добавлена. Сравнение 200-строчных дампов страниц не очень интересно.
Я использовал выделенную консоль администратора, я делал дамп каждой отдельной внутренней таблицы, вставлял строку, а затем еще один дамп системных таблиц. Оба дампа были идентичны, что указывает на то, что, хотя оно сохранилось и, следовательно, должно храниться, оно не подвергается воздействию даже на этом уровне.
Итак, пройдя по кругу, я понял, что у DMV был ответ.
create table foo (MyID int identity not null, MyField char(10))
insert into foo values ('test')
go 10
-- Inserted 10 rows
select Convert(varchar(8),increment_value) as IncrementValue,
Convert(varchar(8),last_value) as LastValue
from sys.identity_columns where name ='myid'
-- insert another row
insert into foo values ('test')
-- check the values again
select Convert(varchar(8),increment_value) as IncrementValue,
Convert(varchar(8),last_value) as LastValue
from sys.identity_columns where name ='myid'
-- delete the rows
delete from foo
-- check the DMV again
select Convert(varchar(8),increment_value) as IncrementValue,
Convert(varchar(8),last_value) as LastValue
from sys.identity_columns where name ='myid'
-- value is currently 11 and increment is 1, so the next insert gets 12
insert into foo values ('test')
select * from foo
Result:
MyID MyField
----------- ----------
12 test
(1 row(s) affected)
Только потому, что строки были удалены, последнее значение не было сброшено, поэтому последнее значение + приращение должно быть правильным ответом.
Также напишу эпизод в моем блоге.
Да, и кратчайший путь ко всему этому:
select ident_current('foo') + ident_incr('foo')
Так что на самом деле все получается просто - но все это предполагает, что никто другой не использовал ваш идентификатор, пока вы его вернули. Хорошо для расследования, но я не хотел бы использовать это в коде.