У меня есть запрос, который позволяет мне удалить все строки и сбросить все столбцы идентификаторов всех моих таблиц без разрыва ссылок на внешние ключи.Этот запрос прекрасно работает для обычных таблиц SQL Server:
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL';
EXEC sp_MSForEachTable 'DELETE FROM ?';
EXEC sp_MSForEachTable 'ALTER TABLE ? WITH CHECK CHECK CONSTRAINT ALL';
EXEC sp_MSforeachtable @command1 = 'DBCC CHECKIDENT (''?'', RESEED, 0)';
Проблема в том, что теперь, когда я использую временные таблицы с системными версиями, предыдущий запрос больше не работает.Мои версионные таблицы имеют имя tbl_Foo
, и каждая таблица истории имеет формат tbl_Foo_history
.
. Я пытался использовать что-то вроде этого:
EXEC sp_MSForEachTable 'ALTER TABLE ? SET (SYSTEM_VERSIONING = OFF)';
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL';
EXEC sp_MSForEachTable 'DELETE FROM ?';
EXEC sp_MSForEachTable 'ALTER TABLE ? WITH CHECK CHECK CONSTRAINT ALL';
EXEC sp_MSforeachtable @command1 = 'DBCC CHECKIDENT (''?'', RESEED, 0)';
EXEC sp_MSforeachtable 'ALTER TABLE ? SET (SYSTEM_VERSIONING = ON (HISTORY_TABLE = ''?''_history))';
, но выдает ошибку:
SYSTEM_VERSIONING is not turned ON for table 'FOO.dbo.tbl_Foo_history'.
, поскольку sp_MSForEachTable
явно запутывается при попытке удалить управление версиями из таблицы истории.
Как это сделать без указания запросов по отдельностидля каждого стола?