Все наверное сталкивались с необходимостью быстро очистить базу данных от документов. Но средствами платформы это растягивается н довольно продолжительный период времени. Я пошел простым путем: очищаем в SQL все таблицы документов и регистров и останется только вручную очистить регистры сведений привязанные к регистратору.
Вот собственно текст SQL запроса:
DECLARE @sql varchar(500)
DECLARE c CURSOR FOR
--Получаем список таблиц документов и регистров document-документы и табличные части, accnt-регистры бухгалтерии, accttl- итоги по регистрам бухгалтерии, accum- регистры накопления с итогами
SELECT [name] FROM sysobjects WHERE (name LIKE '%document%' or name LIKE '%accnt%' or name LIKE '%accttl%' or name LIKE '%accum%') AND xtype = 'U'
OPEN c
--цикл по отобранным таблицам
FETCH NEXT FROM c INTO @sql
WHILE @@FETCH_STATUS = 0
BEGIN
--Формируем текст для очищения таблицы
SET @sql = 'delete from ' + @sql
--Выполняем очищение таблицы
--EXEC (@sql)
PRINT @sql
FETCH NEXT FROM c INTO @sql
END
CLOSE c
DEALLOCATE c
Внимание в приведенном выше запросе закоментирована строка выполяющая очищение таблицы (EXEC...).
Выполнение запроса с раскомментированой строкой выполнять на свой страх и риск.