Основана на публикации //infostart.ru/public/92372/ с доработкой для возможности сохранения сеанса для дальнейшего продолжения с места остановки. В оригинальной обработке при повторном запуске, повторно сканировались объекты, удаление которых невозможно.
В доработке текущий сеанс сохраняется во внешний файл. При поэтапном удалении состояние возможно восстановить из внешнего файла, удаление продолжается с момента остановки.
Полезно для распределенных баз, в которых критичен объем пакета для обмена, т.е. нет возможности удалить все за один подход.
+ Удаление пакета завернуто в транзакцию (все элементы пакета должны быть удалены вместе). В случае возникновения ошибки, например, при блокировке транзакции СУБД, отменяется удаление всего пакета. Удалить объекты пропущеного пакета можно начав удаление заново (без утановленной галочки «Продолжить выполнение удаления»).
Оригинальное описание:
Обработка разрабатывалась для удаления помеченных объектов после свертки большой базы, когда штатный механизм удаления падал на ошибке «недостаточно памяти»
Позволяет найти все помеченные объекты базы данных, сохранить этот список во внешний файл — в случае если при выполнении произойдёт ошибка этап поиска можно будет пропустить, и приступить непосредственно к удалению
В обработке указывается размер пакета — из списка помеченных на удаление объектов формируется пакет заданного размера, на объекты из пакета выполняется поиск ссылок, на найденные объекты также выполняется поиск ссылок и т.д. — т.е. формируется некое «дерево» подчиненных ссылок, и затем, если это возможно — удаляются все объекты этого дерева
Обработка не позволяет выбирать определенные объекты — она старается удалить все помеченные на удаление объекты
Работает под толстым клиентом






ещё добавлю что неплохо бы всё таки иметь возможность из регистров удалять записи
тк например если в регистре сведений есть ссылка на элемент справочника помеченнй на удаление, то например у меня запись в регистре не удаляется.
может придётся доработать самому…
Ошибка при открытии обработки:
{Форма.Форма.Форма(14,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)
Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаСохраненияСтатусаВыполнения) Тогда
{Форма.Форма.Форма(21,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)
Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаЛогов) Тогда
(4) ortpro, Надо заменить «ЗначениеНеЗаполнено(» на «НЕ ЗначениеЗаполнено(«
А что означает параметр «Максимум для удаления» ?
(6) vis_tmp, обработка берет количество элементов равное «Максимум для удаления элементов», делает поиск всех связанных объектов (все «дерево» связанных объектов). После нахождения всех зависимых элементов, все они удаляются в одной транзакции. Так вот — «Максимум для удаления элементов» — это то количество элементов, с которого начинается поиск зависимых. Чем больше это число, тем больше вероятность того, что конечная выборка получится очень большой.
(4) ortpro, «ЗначениеНеЗаполнено» — так сложилось исторически, что в нашей конфигурации была такая функция. vis_tm правильно написал, необходимо заменить на «НЕ ЗначениеЗаполнено»
А почему с кнопкой продолжить выполнять удаление, идет удаление и останавливается, приходится постоянно нажимать удалить?
В обработке следующие методические ошибки:
1. Выполняется поиск по ссылке удаляемых объектов в табличной части обработки, что приводит к снижению производительности.
Наиболее простой способ оптимизации для цикла поиска связанных элементов — выгрузить табличную часть в таблицу значений и добавить индекс по колонке Ссылка:
2. Неправильно выбран тип данных для таблицы УдаляемыеОбъектыПакета, что приводит к значительному снижению производительности.
Вместо таблицы значений доступ к свойствам ссылок необходимо организовывать через тип Соответствие следующим способом:
…
Показать
И, проверка / получение свойств ссылки:
3. Кроме того, прочие ошибки…
(10)
А какие?
(11)
Ошибка сообщений состояний выполнения:
a. Некорректно выстроена система уведомления о неизвестных метаданных. Правильно — запоминать, какие сообщения были уже выданы пользователю, и повторно их не выдавать
Логическая ошибка:
b. в строках модуля объекта 148-153 копипастом перепутаны идентификаторы переменных начинает добавляться строка в переменной «НоваяСтрока», заканчивает заполняться реквизитами в переменной предыдущего цикла «НоваяСтрокаУдаляемыеОбъектыПакета»
Обработка не рабочая.