gifts2017

Пакетное удаление помеченных объектов (Модифицированная)

Опубликовал Андрей Батыренко (mandbat) в раздел Администрирование - Чистка базы

Обработка предназначена для удаления больших объемов помеченных на удаление объектов, когда стандартный механизм "валится" на ошибке "Недостаточно памяти". Основана на публикации http://infostart.ru/public/92372/ с доработкой возможности сохранения сеанса для дальнейшего продолжения с места остановки. Полезно для распределенных баз, в которых критичен объем пакета для обмена.

Основана на публикации http://infostart.ru/public/92372/ с доработкой для возможности сохранения сеанса для дальнейшего продолжения с места остановки. В оригинальной обработке при повторном запуске, повторно сканировались объекты, удаление которых невозможно. 

В доработке текущий сеанс сохраняется во внешний файл. При поэтапном удалении состояние возможно восстановить из внешнего файла, удаление продолжается с момента остановки.

Полезно для распределенных баз, в которых критичен объем пакета для обмена, т.е. нет возможности удалить все за один подход.

+ Удаление пакета завернуто в транзакцию (все элементы пакета должны быть удалены вместе). В случае возникновения ошибки, например, при блокировке транзакции СУБД, отменяется удаление всего пакета. Удалить объекты пропущеного пакета можно начав удаление заново (без утановленной галочки "Продолжить выполнение удаления").

 

Оригинальное описание:

Обработка разрабатывалась для удаления помеченных объектов после свертки большой базы, когда штатный механизм удаления падал на ошибке "недостаточно памяти"

Позволяет найти все помеченные объекты базы данных, сохранить этот список во внешний файл - в случае если при выполнении произойдёт ошибка этап поиска можно будет пропустить, и приступить непосредственно к удалению

В обработке указывается размер пакета - из списка помеченных на удаление объектов формируется пакет заданного размера, на объекты из пакета выполняется поиск ссылок, на найденные объекты также выполняется поиск ссылок и т.д. - т.е. формируется некое "дерево" подчиненных ссылок, и затем, если это возможно - удаляются все объекты этого дерева

Обработка не позволяет выбирать определенные объекты - она старается удалить все помеченные на удаление объекты

Работает под толстым клиентом

Скачать файлы

Наименование Файл Версия Размер
ПакетноеУдалениеПомеченныхОбъектов v2.3 242
.epf 15,37Kb
20.04.12
242
.epf 15,37Kb Скачать

См. также

Подписаться Добавить вознаграждение

Комментарии

3. Tolik (gortol) 11.07.12 18:00
ещё добавлю что неплохо бы всё таки иметь возможность из регистров удалять записи

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

может придётся доработать самому...
4. Олег Ортман (ortpro) 25.04.13 08:16
Ошибка при открытии обработки:

{Форма.Форма.Форма(14,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)
Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаСохраненияСтатусаВыполнения) Тогда
{Форма.Форма.Форма(21,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)
Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаЛогов) Тогда
5. v i (vis_tmp) 16.11.14 10:02
(4) ortpro, Надо заменить "ЗначениеНеЗаполнено(" на "НЕ ЗначениеЗаполнено("
6. v i (vis_tmp) 16.11.14 10:39
А что означает параметр "Максимум для удаления" ?
7. Андрей Батыренко (mandbat) 16.11.14 11:06
(6) vis_tmp, обработка берет количество элементов равное "Максимум для удаления элементов", делает поиск всех связанных объектов (все "дерево" связанных объектов). После нахождения всех зависимых элементов, все они удаляются в одной транзакции. Так вот - "Максимум для удаления элементов" - это то количество элементов, с которого начинается поиск зависимых. Чем больше это число, тем больше вероятность того, что конечная выборка получится очень большой.
8. Андрей Батыренко (mandbat) 16.11.14 11:09
(4) ortpro, "ЗначениеНеЗаполнено" - так сложилось исторически, что в нашей конфигурации была такая функция. vis_tm правильно написал, необходимо заменить на "НЕ ЗначениеЗаполнено"
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа