Удаление дубликатов версий объектов (чистка регистра сведений "Версии объектов")

26.10.20

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

Из-за частого перепроведения документов и включенного версионирования очень разрослась база. Написал обработку, которая удаляет одинаковые версии.

Файлы

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

Наименование Скачано Купить файл
Удаление дубликатов версий объектов (чистка регистра сведений "Версии объектов"):
.epf 19,26Kb
17 1 850 руб. Купить

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

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

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

Конфигурация УТП для Украины. Включено версионирование. Регистр "Версии объектов" сильно уж разросся из-за частого перепроведения документов. Написал обработку, которая удаляет одинаковые версии.

Выбираем типы объектов (таблица типов подтягивается из метаданных), для документов выбираем период (самих документов). Также можно выбрать конкретный объект.

Обработка последовательно анализирует версии каждого отобранного объекта. Если следующая версия не изменялась по отношению к текущей, то "следующая" версия удаляется.

Одним запросом отбираются все записи регистра "Версии объектов" с отбором по указанным объектам. Далее идет группировка версий по объектам. Для каждого объекта "читается" набор записей (регистр сведений "Версии объектов"). При необходимости ненужные версии удаляются и набор записей записывается.

Такой алгоритм выбран из-за того, что он не мешает штатной работе сотрудников и можно удалять версии в рабочее время.

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

Тестировалось на платформе 8.3.10.2252 в конфигурации "Управление торговым предприятием для Украины", редакция 1.2 (1.2.57.1)"

 

UPD: Перезалил файл обработки так как нашел жесткий косяк: не сравнивались табличные части объектов, а только реквизиты шапки... Исправлено.

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

обработка версии объектов уменьшение объема базы

См. также

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

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

14400 руб.

20.08.2024    44750    247    123    

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    142830    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    260859    235    83    

270

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

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

9600 руб.

17.09.2013    806613    58    51    

94

Чистка данных Программист Пользователь 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    28663    77    20    

93

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

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

5136 руб.

23.08.2021    11231    23    3    

29

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

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

2400 руб.

09.04.2019    30468    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    11346    249    WeterSoft    7    

16
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Cyberhawk 136 24.10.20 13:00 Сейчас в теме
А каким образом определяется, одинаковая ли версия или нет?
4. A_Sa 3 26.10.20 17:19 Сейчас в теме
(1) Тупо сравниваются все реквизиты шапки и табличных частей :)
Если в одной из версий есть реквизит, а в другом его нет (добавили или удалили сам реквизит в конфигураторе), то проверяется заполненность значения данного реквизита в версии, где он присутствует.
Не очень элегантно и быстро, но мне главное был результат :)
Cyberhawk; +1 Ответить
2. Rokky78 42 26.10.20 12:11 Сейчас в теме
Тоже приходилось писать подобный инструмент для отраслевой конфигурации со старой БСП. Там механизм версионирования был, но в зачаточном состоянии. Но кроме этого инструмента (чтобы не чистить регистр все время), добавил в алгоритм при записи объекта запись только измененной версии. Т.е. сравнение версии происходит при записи объекта. Если новая версия такая же как предыдущая - запись версии не происходит. Больше ту обработку не вспоминаю :)

P.S. в моем случае сравнивались хэши данных Fast Infoset.
3. FatPanzer 26.10.20 12:20 Сейчас в теме
(2) Думаю, что тратить время на сравнение версий при при записи - не самый оптимальный вариант при высоконагруженных системах. Но, конечно, все зависит от прикладной логики.
5. A_Sa 3 26.10.20 17:22 Сейчас в теме
(2) Тоже думал над вариантом сравнения версий при записи объектов, но, как уже написал FatPanzer посчитал неоптимальным в плане нагрузки. Мне проще раз в месяц запускать эту обработку на выходных, когда пользователей в базе по минимуму.
6. user1464234 26.10.20 17:27 Сейчас в теме
А сравнивать сериализованное значение с записанным в историю не проще?
7. A_Sa 3 26.10.20 17:40 Сейчас в теме
(6) Имеете в виду: при записи объекта сравнивать? Просто в базе уже было накоплено куча версий и их нужно было почистить, поэтому обработка по удалению все-равно нужна. А дальше уже можно что-то сделать, чтоб эти версии не появлялись. И опять же, как писал раньше: мне сейчас проще раз в месяц на выходных запускать эту обработку :)
user1464234; +1 Ответить
8. zaogorizont 23.12.20 21:13 Сейчас в теме
Доброго времени суток , загрузил вашу обработку и запустил через файл открыть в ЕРП 2-4-13-71 , (((( пустой экран
9. A_Sa 3 24.12.20 00:09 Сейчас в теме
(8) Здарвствуйте. Эта обработка для обычных форм, а ЕРП на управляемых... Постараюсь найти время в ближайшую неделю, чтоб доработать под управляемые формы. Но я не уверен, что даже в этом случае подойдет для вашей конфигурации - там может быть другой механизм версионирования.
10. zaogorizont 12.01.21 04:50 Сейчас в теме
(9) ждем от вас на управляемых формах
11. zaogorizont 08.02.21 15:15 Сейчас в теме
(9) Добрый день ! Подскажите когда пришлете на управляемых формах ?
12. zaogorizont 08.02.21 22:37 Сейчас в теме
(9) пытался воспользоваться обработкой для удаления в одном типе документа и выдал ошибку

Ошибка разбора XML: - [1,1]
Фатальная ошибка:
Document is empty

{ВнешняяОбработка.УдалениеДубликатовВерсийОбъектов.Форма.Форма1.Форма(525)}: Пока ЧтениеXML.Прочитать() Цикл
{ВнешняяОбработка.УдалениеДубликатовВерсийОбъектов.Форма.Форма1.Форма(481)}: Результат = РазборПредставленияОбъектаXML(СтрокаXML, Ссылка);
{ВнешняяОбработка.УдалениеДубликатовВерсийОбъектов.Форма.Форма1.Форма(295)}: ТекВерсия = РазборВерсии(СтрокиВерсий[ИндВерсии].НомерВерсии, СтрокиВерсий[ИндВерсии].Объект);
{ВнешняяОбработка.УдалениеДубликатовВерсийОбъектов.Форма.Форма1.Форма(214)}: УдалитьДубликатыВерсийОбъектов(МассивСсылок);
{ВнешняяОбработка.УдалениеДубликатовВерсийОбъектов.Форма.Форма1.Форма(226)}: УдалитьДубликатыНаСервере();

по причине:
Ошибка разбора XML: - [1,1]
Фатальная ошибка:
Document is empty
13. triviumfan 102 05.10.21 14:25 Сейчас в теме
Не пойму, зачем эта обработка, если в случае, когда объект не менялся будет всего лишь запись в регистре с пустой версией.
Зачем удалять "дубликаты" - не понятно.
Плюс есть регламентное задание по очистке устаревших версий.
Я в недоумении.
14. zaogorizont 19.10.21 21:11 Сейчас в теме
ерп 2.4.6.209 при запуске выдал пустой экран
Для отправки сообщения требуется регистрация/авторизация