Очистка клиент-серверных вариантов баз 1С 8.X

14.01.09

База данных - Чистка данных

Текст SQL запроса предназначенный для очистки таблиц документов, регистров накоплений и регистров бухгалтерии.
Работает на SQL 2000 на 2005 наверное тоже но не проверял.

Все наверное сталкивались с необходимостью быстро очистить базу данных от документов. Но средствами платформы это растягивается н довольно продолжительный период времени. Я пошел простым путем: очищаем в 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...).
Выполнение запроса с раскомментированой строкой выполнять на свой страх и риск.

 

См. также

Удаление данных с отбором и построением дерева ссылок в базах 1С 8.1-8.3 УТ 10.3./11, БП 2/3, ЗУП 2.5/3, КА 1.1/2, УНФ 1.6/3.0

Чистка данных Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 1С:Управление торговлей 10 1С:Управление торговлей 11 Платные (руб)

Данные обработки помогут Вам легко и, главное быстро, выполнить удаление любых данных в Ваших базах 1С на платформах 8.1-8.3. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 04.10.2023, версия 4.2)

9600 руб.

22.02.2013    136194    249    144    

418

Универсальное выборочное удаление данных из базы 1С (любые конфигурации на упр.формах: БП 3.0, УТ 11, КА 2, ERP, УНФ, ЗУП 3, Розница и т.д.)

Чистка данных Платформа 1С v8.3 Управляемые формы 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Обработка позволяет удобно выборочно удалить данные из базы 1С. Это могут быть как неиспользуемые элементы справочников, так и неактуальные организации. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся.

3350 руб.

28.11.2019    24471    49    16    

62

SALE! 10%

Выборочное удаление организаций из баз (управляемые формы), с удалением всех ссылающихся на эти организации данных

Чистка данных Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Позволяет удалить организации из любых программ на управляемых формах (БП 3.0, УТ 11, КА 2, ERP 2, ЗУП 3.0, УНФ, Розница 2.0 и пр.). Главное требование - программа должна содержать справочник "Организации". Реализован самый быстрый алгоритм непосредственного удаления объектов. Работает даже на базах большого размера. Для ускорения работы алгоритма не запускается проверка контроля ссылочной целостности. Проверку учета можно запустить отдельно с помощью дополнительной обработки. Необходимо перед удалением самостоятельно проверить базу на наличие перекрестных ссылок разных организаций в одном документе. Эту дополнительную обработку проверки перекрестных ссылок по запросу предоставляем бесплатно нашим покупателям.

3980 3582 руб.

16.03.2015    114045    182    77    

218

Замена Номенклатуры+Характеристики

Чистка данных Логистика, склад и ТМЦ Платформа 1С v8.3 План видов характеристик 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Настраиваемая обработка, позволяющая заменить пару: Номенклатура+Характеристика в документах, их движениях и независимых регистрах сведений. Без перепроведения. Поможет, если вы по каким-то причинам решили отказаться от характеристик

3600 руб.

04.08.2015    41213    89    70    

50

Удаление битых ссылок 1С в базе без монопольного режима

Чистка данных Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Если в вашей информационной базе крутится очень много данных, или база должна быть доступна 24/7 (как в моем случае), или же вы боитесь запускать тестирование и исправление, НО существует потребность удалить битые ссылки, тогда эта обработка сможет Вам помочь. Обработка выявляет битые ссылки как в самих объектах метаданных, так и в их табличных частях(!), а так же может их удалить.

2400 руб.

23.08.2021    9303    15    3    

20

Очистка регистров сведений от записей по помеченным на удаление элементам

Чистка данных Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

в современных конфигурациях стало очень много регистров сведений, хранящих вспомогательную и периодическую информацию и администраторы информационных систем стали сталкиваться с проблемой удаления помеченных на удаление объектов, так как ссылки на них хранятся в многочисленных регистрах сведений. Помочь почистить базу от ненужных записей предназначенная данная внешняя обработка на управляемой форме, которая ищет записи во всех регистрах сведений по помеченным на удаление объектах и очищает по ним записи их после использования данной обработки дальше можно смело пользоваться типовой обработкой удаление помеченных на удаление и проблем с удалением не возникнет! Удачи всем!

1200 руб.

21.01.2022    7172    5    6    

9

Очистка кэша 1С. Исполнитель

Чистка данных Инструментарий разработчика Платформа 1С v8.3 Абонемент ($m)

Очередная вариативная очистка кэша 1С с помощью Исполнителя 3.0.2.2.

1 стартмани

25.10.2023    4635    4    SerVer1C    25    

22

Очистка регистра накопления. Очистка регистра сведений.

Чистка данных Платформа 1С v8.3 Управляемые формы Платформа 1C v8.2 Конфигурации 1cv8 Бесплатно (free)

ВАЖНО!!! Очистку регистров накопления и регистров сведений рекомендуется делать пользователям со знанием дела и с осознанием последствий! Обработка поможет быстро очистить выбранный регистр. Делаю данную обработку в первую очередь для себя, т.к. были случаи, когда нужно было очищать регистры, а делать красиво и удобно времени не было.

06.02.2023    13082    873    Neiron_1C    15    

18
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. boggonzikov 339 16.01.09 10:25 Сейчас в теме
Полезная вещь, особенно для подготовки базы для разработки из реальной, как правило огромной Рабочей базы.
Только еще не хватает условия по дате.
Т.е. хочу в базе оставить только данные за 1 месяц. Подскажи как сделать?
+
3. Gamm 13 16.01.09 15:17 Сейчас в теме
(1) Вот вариант кода который очистит регистры с периодом больше заданной и все документы.
С документами побольше написать надо. Чтоб в начале пробежаться по табличным частям и их очистить и только потом сами таблицы документов.
Будет время уделю этому внимания.
Begin
SET @sql = 'delete from ' + @sql +' where _Period>=CONVERT(DATETIME, ''''2008-01-01 00:00:00'''', 102)'
PRINT @sql
End
else --иначе просто очищаем таблицу командой truncate которая сработает быстрее чем delete
SET @sql = 'truncate ' + @sql
+
5. boggonzikov 339 16.01.09 17:51 Сейчас в теме
(3)
>пробежаться по табличным частям
Как раз этого и не хватает, я не давно тоже писал похожую обработку, но из-за не знания СКЛ, пошел другим путем, через 1С. Получал структуру данных и название таблиц хранения, а затем простыми запросами удалял. Типа

|TRUNCATE _" + таблица + "" ;
или
|DELETE
|
|From _" + таблица + " WHERE _" + таблица + "._period < DATE '2008-03-01' " ;

Удаление таб. частей было
|DELETE FROM " + таблица + " WHERE
|"+НазваниеОсновнойТаблицы+"_idrref IN
| (SELECT _idrref FROM " + НазваниеОсновнойТаблицы + " WHERE " + НазваниеОсновнойТаблицы + "._date_time < DATE '2008-03-01') " ;

+
2. PVG_73 17 16.01.09 11:06 Сейчас в теме
Помнится такую же хрень я писал для 7.7.... :)
Удобная весчь, особенно когда режишь или клонируешь бызы...
можно добавить и справочники и исключения по ним, если в этом есть необходимость...
+
4. Gamm 13 16.01.09 15:34 Сейчас в теме
Если дополнительных отборов не нужно советую заменить строчку
SET @sql = 'delete from ' + @sql
на строчку
SET @sql = 'truncate ' + @sql

+
6. ilya005 123 30.01.10 20:36 Сейчас в теме
аналог для 7.7
DECLARE @sql varchar(500)
DECLARE c CURSOR FOR
--Получаем список таблиц документов и регистров document-документы и табличные части, accnt-регистры бухгалтерии, accttl- итоги по регистрам бухгалтерии, accum- регистры накопления с итогами
SELECT [name] FROM sysobjects WHERE (
name LIKE 'D%' or
name LIKE 'R%' or
name LIKE '_1SCRDOC' or
name LIKE '_1SJOURN' or
name LIKE '_1SCRDOC') AND xtype = 'U'
OPEN c
--цикл по отобранным таблицам
FETCH NEXT FROM c INTO @sql
WHILE @@FETCH_STATUS = 0
BEGIN
--Формируем текст для очищения таблицы
SET @sql = 'truncate table ' + @sql
--Выполняем очищение таблицы
EXEC (@sql)
PRINT @sql
FETCH NEXT FROM c INTO @sql
END
CLOSE c
DEALLOCATE c
+
7. Abadonna 3958 30.01.10 20:43 Сейчас в теме
(0) Ох, опасная игрушка в неумелых руках ;)
+
8. PowerBoy 3363 27.12.12 12:15 Сейчас в теме
Кому надо - вот универсальная чистилка документов с любыми отборами:
http://infostart.ru/public/16731/
+
Оставьте свое сообщение