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

22.05.20

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

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

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Поиск неиспользуемых объектов справочников и их удаление:
.epf 10,57Kb
85 1 850 руб. Купить

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

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

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

Дисклеймер:  Досталась мне в наследство переделанная УТ 11 и задача по обмену между ней и УНФ. При обмене выяснилось, что справочник серий переносится чрезвычайно долго, а при ближайшем рассмотрении оказалось, что половина справочника фантомная. Попытка пометить всё на удаление и удалить не увенчалась успехом из-за того, что такой объем не успевал очиститься штатными средствами за время технологического окна.

Были испробованы несколько обработок с текущего сайта, но они все помогали мне лишь отчасти. Решено! Делаем свой велосипед.

Велосипед:

Задачи велосипеда:

  1. Найти неиспользованные объекты в базе
  2. Пометить их на удаление
  3. Удалить окончательно (опционально).

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

Из фишек:

  • Поиск неиспользованных ссылок запросом, а не родной функцией
  • Пометка на удаление "пачками" по N штук
  • Удаление из базы без СМС и регистраций теми же пачками.
  • Удаление из базы с дополнительной проверкой с помощью НайтиПоСсылкам(). Работает гораздо медленней, но помогает при паранойе.
  • Поиск неиспользованных, учитывая уже помеченные на удаление места использования (Например, ищем номенклатуру. Если она используется только в документах уже помеченных на удаление - отбираем и её)

В планах:

  • Добавить возможность поиска и по документам
  • Добавить рекурсивное удаление
  • Добавить множественный выбор справочников

 

Инструкция к велосипеду:

  1. Выбрать нужный справочник
  2. Установить количество удаляемых за раз
  3. Установить галку "Учитывать помеченные", если хотим, чтобы ссылки на помеченные на удаление объекты не учитывались
  4. Установить галку "Доп проверка ссылок", если хотим, чтобы осуществляло двойную проверку (во время поиска и непосредственно перед удалением)
  5. Нажать "Поиск". Должна заполниться ТЧ 
  6. Нажать "Пометка на удаление". Объекты из ТЧ пометятся на удаление
  7. Нажать "Удаление". Объекты удалятся

Обработка тестировалась на платформах версий 8.3.16.1148 и 8.3.12.1685. В принципе, должна работать на любых версиях моложе 8.3.6.

Тестировалась на конфигурации УТ 11.2, но должна работать на любых, использующих БСП. 

удаление очистка свертка поиск ссылок помеченные на обработка

См. также

SALE! 15%

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

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

8400 7140 руб.

20.08.2024    32729    201    104    

188

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

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

10800 руб.

22.02.2013    140886    273    146    

444

Чистка данных Системный администратор Программист 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 и пр.). Главное требование - программа должна содержать справочник "Организации". Реализован самый быстрый алгоритм непосредственного удаления объектов. Работает даже на базах большого размера. Для ускорения работы алгоритма не запускается проверка контроля ссылочной целостности. Проверку учета можно запустить отдельно с помощью дополнительной обработки. Необходимо перед удалением самостоятельно проверить базу на наличие перекрестных ссылок разных организаций в одном документе. Эту дополнительную обработку проверки перекрестных ссылок по запросу предоставляем бесплатно нашим покупателям.

3582 руб.

16.03.2015    225618    228    83    

263

Чистка данных Программист Пользователь 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, Розница и др. Это могут быть как неиспользуемые элементы справочников, так и неактуальные организации. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся.

3350 руб.

28.11.2019    27503    72    18    

87

Чистка данных Системный администратор Программист Бухгалтер Пользователь Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

Решение по удалению дублей позволяет определить связанные элементы в двух синхронизированных базах в качестве оригиналов и избежать необходимости ручного сравнения объектов в базах перед синхронизацией.

6000 руб.

27.06.2018    19729    16    3    

20

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

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

2400 руб.

23.08.2021    10623    21    3    

27

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

Такое бывает? Удалили документ, а проводки (движения) остались? Эта простая обработка решает данную проблему.. почему по проводкам? да потому что обычно такие вещи замечают именно бухгалтера.на самом же деле данная обработка при нахождении документа удаленного или помеченного на удаление и имеющего движения очищает все движения без исключений.

3000 руб.

06.02.2012    37020    363    30    

32

Чистка данных Системный администратор Программист 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    10128    222    WeterSoft    5    

15
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. simuljakr 207 27.05.20 14:12 Сейчас в теме
Здравствуйте!
Спасибо за разработку.
Вы пишете:
Для поиска ссылок генерируется запрос по всем метаданным, где используется выбранный справочник


А как вы определяете список метаданных, в которых использовался данный справочник?
2. alexlx 115 27.05.20 16:17 Сейчас в теме
(1) Добрый день. Я пробегаю по всем метаданным и их реквизитам и ТЧ, и если тип реквизита совпадает с искомым - добавляю его в запрос.
simuljakr; +1 Ответить
3. simuljakr 207 28.05.20 09:46 Сейчас в теме
(2) А если тип реквизита составной, это учитывается ?
4. alexlx 115 28.05.20 09:49 Сейчас в теме
5. Chtcom 29.08.20 05:32 Сейчас в теме
Здравствуйте! Бухгалтерия предприятия, редакция 3.0 (3.0.81.25) к сожалению, ошибка обработки справочника номенклатуры.
Прикрепленные файлы:
6. 13D 73 17.09.21 13:36 Сейчас в теме
чёт не работает на новых релизах...
7. Tarlich 119 09.02.22 18:40 Сейчас в теме
Добрый день ! БП 3 ... 1)как можно пометить на удаление номенклатуру по которой не было движения (документов) но есть док.УстановкаЦен ?
2) так же надо удалить Договора и контрагентов без движений
Справиться ?
10. alexlx 115 15.04.22 15:35 Сейчас в теме
(7)
Добрый день ! БП 3 ... 1)как можно пометить на удаление номенклатуру по которой не было движения (документов) но есть док.УстановкаЦен ?
2) так же надо удалить Договора и контрагентов без движений
Справиться ?


Для 1) я бы использовал ИР от tormizit. Сначала запросом получить номенклатуру, потом обработкой пометить на удаление.
Моя обработка не пометит, так как есть УстановкаЦен
2) Должно сработать
8. пользователь 13.04.22 07:59
Сообщение было скрыто модератором.
...
9. пользователь 15.04.22 15:32
Сообщение было скрыто модератором.
...
11. ufedor 58 08.12.22 15:40 Сейчас в теме
Наконец-то нашел правильный велосипед, а то НайтиПоСсылкам() любой может сделать но это слабо помогает при больших справочниках.
Респект!

Предложение по улучшению: ссылки некоторые объекты встречаются во многих местах, и запрос получится монструозный. А для некоторых версий mssql слишком сложный запрос просто невозможно выполнить. Думаю стоит добавить разделение запроса на "пакеты" например не больше 100 штук, в одном из проектов я так делал.
Оставьте свое сообщение