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

Администрирование - Чистка базы

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

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

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

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

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

 

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

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

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

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

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

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

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

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

См. также

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

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

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

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

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

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

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


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

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

...

Функция НовыйИндекс(СоответствиеСсылок, Знач Ссылка, Знач ИндексСтроки)
	
	СтруктураСсылки = Новый Структура("Ссылка, Удаляется, Ссылок, НеУдаляемыхСсылок", Ссылка, Истина, 0, 0);
	СтруктураСсылки.Вставить("ИндексСтроки", ИндексСтроки);
	
	СоответствиеСсылок.Вставить(Ссылка, СтруктураСсылки);
	
	Возврат СтруктураСсылки;
	
КонецФункции

...
	УдаляемыеОбъектыПакета = Новый Соответствие;

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


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

...

СтрокаСсылки = УдаляемыеОбъектыПакета.Получить(Ссылка);

...

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

3. Кроме того, прочие ошибки...
11. v i (vis_tmp) 27 25.05.17 12:07 Сейчас в теме
(10)
3. Кроме того, прочие ошибки...
А какие?
12. Дмитрий Дудин (dmurk) 87 25.05.17 16:58 Сейчас в теме
(11)

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

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