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

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

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

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

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

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

 

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

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

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

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

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

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

11 Comments

  1. gortol

    ещё добавлю что неплохо бы всё таки иметь возможность из регистров удалять записи

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

    может придётся доработать самому…

    Reply
  2. ortpro

    Ошибка при открытии обработки:

    {Форма.Форма.Форма(14,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)

    Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаСохраненияСтатусаВыполнения) Тогда

    {Форма.Форма.Форма(21,8)}: Процедура или функция с указанным именем не определена (ЗначениеНеЗаполнено)

    Если <<?>>ЗначениеНеЗаполнено(ИмяФайлаЛогов) Тогда

    Reply
  3. vis_tmp

    (4) ortpro, Надо заменить «ЗначениеНеЗаполнено(» на «НЕ ЗначениеЗаполнено(«

    Reply
  4. vis_tmp

    А что означает параметр «Максимум для удаления» ?

    Reply
  5. mandbat

    (6) vis_tmp, обработка берет количество элементов равное «Максимум для удаления элементов», делает поиск всех связанных объектов (все «дерево» связанных объектов). После нахождения всех зависимых элементов, все они удаляются в одной транзакции. Так вот — «Максимум для удаления элементов» — это то количество элементов, с которого начинается поиск зависимых. Чем больше это число, тем больше вероятность того, что конечная выборка получится очень большой.

    Reply
  6. mandbat

    (4) ortpro, «ЗначениеНеЗаполнено» — так сложилось исторически, что в нашей конфигурации была такая функция. vis_tm правильно написал, необходимо заменить на «НЕ ЗначениеЗаполнено»

    Reply
  7. Samir

    А почему с кнопкой продолжить выполнять удаление, идет удаление и останавливается, приходится постоянно нажимать удалить?

    Reply
  8. dmurk

    В обработке следующие методические ошибки:

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

    Наиболее простой способ оптимизации для цикла поиска связанных элементов — выгрузить табличную часть в таблицу значений и добавить индекс по колонке Ссылка:

    УдаляемыеОбъектыКопия = УдаляемыеОбъекты.Выгрузить();
    УдаляемыеОбъектыКопия.Индексы.Добавить(«Ссылка»);

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

    Вместо таблицы значений доступ к свойствам ссылок необходимо организовывать через тип Соответствие следующим способом:

    Функция НовыйИндекс(СоответствиеСсылок, Знач Ссылка, Знач ИндексСтроки)
    
    СтруктураСсылки = Новый Структура(«Ссылка, Удаляется, Ссылок, НеУдаляемыхСсылок», Ссылка, Истина, 0, 0);
    СтруктураСсылки.Вставить(«ИндексСтроки», ИндексСтроки);
    
    СоответствиеСсылок.Вставить(Ссылка, СтруктураСсылки);
    
    Возврат СтруктураСсылки;
    
    КонецФункции
    
    …
    УдаляемыеОбъектыПакета = Новый Соответствие;
    
    ПроверяемыеСсылки = Новый Массив;
    Для Каждого ЭлементПакета Из Пакет Цикл
    НовыйИндекс(УдаляемыеОбъектыПакета, ЭлементПакета.Ссылка, ЭлементПакета.ИндексСтроки);
    ПроверяемыеСсылки.Добавить(ЭлементПакета.Ссылка);
    КонецЦикла;
    …

    Показать

    И, проверка / получение свойств ссылки:

    …
    
    СтрокаСсылки = УдаляемыеОбъектыПакета.Получить(Ссылка);
    
    …
    
    Если УдаляемыеОбъектыПакета.Получить(СтрокаДанного.Ссылка) = Неопределено Тогда
    

    3. Кроме того, прочие ошибки…

    Reply
  9. vis_tmp

    (10)

    3. Кроме того, прочие ошибки…

    А какие?

    Reply
  10. dmurk

    (11)

    Ошибка сообщений состояний выполнения:

    a. Некорректно выстроена система уведомления о неизвестных метаданных. Правильно — запоминать, какие сообщения были уже выданы пользователю, и повторно их не выдавать

    Логическая ошибка:

    b. в строках модуля объекта 148-153 копипастом перепутаны идентификаторы переменных начинает добавляться строка в переменной «НоваяСтрока», заканчивает заполняться реквизитами в переменной предыдущего цикла «НоваяСтрокаУдаляемыеОбъектыПакета»

    Reply
  11. ben_art

    Обработка не рабочая.

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *