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

20.04.12

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

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

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
ПакетноеУдалениеПомеченныхОбъектов v2.3
.epf 15,37Kb
328 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

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

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

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

 

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

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

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

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

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

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

Вступайте в нашу телеграмм-группу Инфостарт

См. также

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

14400 руб.

20.08.2024    45051    248    126    

228

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

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

12000 руб.

22.02.2013    142899    281    147    

450

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

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

6000 руб.

16.03.2015    261731    235    83    

270

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

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

5000 руб.

28.11.2019    28705    78    21    

93

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

Данные обработки помогут Вам быстро и просто выполнить перезапись любых ссылочных объектов, а также провести/снять с проведения документы с возможностью выбора регистров и произвольными отборами, в Ваших базах 1С на платформах 8.1-8.3. Обработка позволят найти документы с движениями или без них. Все это дает Вам мощный инструмент для работы. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. А также обновления Вы получаете бесплатно в течение года с момента приобретения данных обработок! Данные обработки входят в ТОП-100 продаж, что является залогом популярности, надежности в работе, и признанием других покупателей.

9600 руб.

17.09.2013    806667    58    51    

94

Чистка данных Программист 1С v8.3 1C:Бухгалтерия Платные (руб)

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

5136 руб.

23.08.2021    11262    23    3    

29

Оптовая торговля Логистика, склад и ТМЦ Чистка данных Программист Бухгалтер Пользователь 1С v8.3 Оперативный учет 1С:Управление торговлей 11 Россия Управленческий учет Платные (руб)

Если вы начали работать в программном продукте Управление Торговлей, редакция 11 или Комплексная Автоматизация редакция 2 и включили механизм учёта серий, то перейти обратно в учёт без серий будет не так-то просто. Сложность заключается в том, что нужно очистить серии в табличной части документа, например, Реализация Товаров и услуг. Предлагаем алгоритм перехода на учет без серий для программного продукта УТ11. (Очистка серий.)

2400 руб.

09.04.2019    30477    47    15    

50

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

Универсальный инструмент для очистки базы. Работает как на конфигурациях на основе БСП, так и самописных. Позволяет выбрать данные, отобразить форму списка, увидеть структуру метаданных, очистить базу применяя при необходимости условия. Удаление производится по выбранным элементам в таблице значений. Наложение условий позволяет удалить документы по выбранной организации.

1 стартмани

25.12.2023    11393    250    WeterSoft    7    

16
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. пользователь 03.04.12 23:48
Сообщение было скрыто модератором.
...
2. пользователь 09.04.12 10:12
Сообщение было скрыто модератором.
...
3. gortol 204 11.07.12 18:00 Сейчас в теме
ещё добавлю что неплохо бы всё таки иметь возможность из регистров удалять записи

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

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

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

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

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

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


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

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

...

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

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

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


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

...

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

...

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

3. Кроме того, прочие ошибки...
11. vis_tmp 33 25.05.17 12:07 Сейчас в теме
(10)
3. Кроме того, прочие ошибки...
А какие?
12. dmurk 25.05.17 16:58 Сейчас в теме
(11)

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

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