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

Публикация № 1311372 17.10.20

Администрирование БД - Чистка данных

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

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

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

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

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

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

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

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

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

 

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

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

Наименование Файл Версия Размер
Удаление дубликатов версий объектов (чистка регистра сведений "Версии объектов"):

.epf 19,26Kb
9
.epf 19,26Kb 9 Скачать

Специальные предложения

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

P.S. в моем случае сравнивались хэши данных Fast Infoset.
3. FatPanzer 15 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 28 05.10.21 14:25 Сейчас в теме
Не пойму, зачем эта обработка, если в случае, когда объект не менялся будет всего лишь запись в регистре с пустой версией.
Зачем удалять "дубликаты" - не понятно.
Плюс есть регламентное задание по очистке устаревших версий.
Я в недоумении.
14. zaogorizont 19.10.21 21:11 Сейчас в теме
ерп 2.4.6.209 при запуске выдал пустой экран
Оставьте свое сообщение

См. также

daСклонение: склонение ФИО, должностей, чисел, прилагательных, существительных на языке 1С + ТестЦентр Промо

Универсальные функции v8 1cv8.cf Абонемент ($m)

Функция предназначена для склонения выражений, которые часто требуется при формировании печатных форм договоров и прочих печатных форм. Функция склоняет по падежам ФИО, должности, числительные, валюты, единицы измерения, предметы. Также функция склоняет глаголы и прилагательные по числам и родам и существительные по числам. Имеется режим определения рода переданного выражения. Поддержка форматной строки для вывода результата. Функция не использует внешние библиотеки и веб-сервисы, написана на чистом языке 1С, и поэтому легко встраивается в любую конфигурацию или внешнюю обработку. Правила склонения оформлены в виде таблицы и могут быть легко изменены при необходимости.

1 стартмани

14.02.2015    115489    116    daMaster    90    

Обзор полезных методов БСП 3.1.4

БСП (Библиотека стандартных подсистем) Практика программирования v8 1cv8.cf Бесплатно (free)

Библиотека стандартных подсистем (далее - БСП) является частью любой типовой конфигурации, поэтому умение применять готовые процедуры и функции повышает качество разработки и избавляет от написания лишнего кода. К сожалению, не у всех есть время и упорство овладеть всей документацией, поэтому я собрал воедино наиболее популярный функционал.

25.03.2021    41895    rayastar    51    

Сравнение реального дохода со средним доходом из API.HH.RU

Зарплата Управленческие v8 v8::СПР ЗУП3.x УУ Абонемент ($m)

Внешняя обработка на управляемой форме для 1С:Предприятие 8.3 по интеграции с HH.RU используя HH REST API. Ключевые функции: получение списка вакансий по должностям (Ключ для работы не нужен); расчет среднего дохода; Тестирование проводилось на платформе 1С:Предприятие 8.3 (8.3.13.1513) Зарплата и управление персоналом, редакция 3.1 (3.1.11.68) совместно с API.HH.RU.

1 стартмани

11.11.2019    6185    10    solaru    5    

Конфигурация для рекламного агентства

Управление услугами и сервисом СRM Производство готовой продукции (работ, услуг) СRM Производство готовой продукции (работ, услуг) v8 Реклама, PR и маркетинг УУ Абонемент ($m)

Данная конфигурация выполнена для решения тестового задания: Цель задания: 1) Понять, на каком из клиентов сколько мы заработали;  2) Понять, по какому виду СМИ сколько мы заработали;  3) Проследить по каждой услуге: у кого за сколько купили и кому за сколько продали, с возможностью перейти в соответствующий документ. Реализовано с помощью: 1. Справочники - контрагенты, номенклатура 2. Документы - Поступление услуг, реализация услуг 3. Отчеты - отчет по контрагентам, номенклатуре и движений.

1 стартмани

21.05.2019    8790    0    solaru    0    

Загрузка номенклатуры в УТ 10.3 из Excel файла с генерацией штрихкодов

Загрузка и выгрузка в Excel Обработка справочников Оптовая торговля Розничная торговля Учет ТМЦ Оптовая торговля Розничная торговля Учет ТМЦ v8 УТ10 Россия Абонемент ($m)

Обработка позволяет генерировать новые номенклатурные позиции на основе данных из файла Excel с последующей генерацией штрихкодов (ШК). Может быть полезна при больших поступлениях товаров на склад, где ручное создание и присваивание штрихкода  (ШК) может занимать много времени.

1 стартмани

24.03.2017    9368    7    solaru    0    

Под капотом управляемых форм

Практика программирования v8 1cv8.cf Бесплатно (free)

Управляемые формы уже давно и плотно вошли в жизнь 1С-разработчика. Однако, судя по недавним публикациям на Инфостарте, многие до сих пор мало знакомы с ними. Предлагаю разобраться с тем, что же это такое.

26.08.2013    291565    Evil Beaver    276    

[NotaBene] Универсальный отчет по таблице значений

Практика программирования v7.7 1cv7.md Россия Абонемент ($m)

1C v.7.7 Готовое решение. Не требует настройки. Не требует допрограммирования. Данная обработка решает часто встречающуюся задачу вывода в "красивом" виде таблицы значений (полученной, например, из запроса). Поддерживается произвольное группирование данных, отключение/включение группировок, в т.ч и создание "шахматок" (типа "продажи понедельно"). Обработка может использоваться как и в отладочных целях (для нормального просмотра ТЗ), так и в составе вполне рабочих отчетов. По крайней мере, я неоднократно клиентам данную обработку ставил вместо того, чтобы каждый раз писать замороченные выводы данных. И клиенты довольны, и мне - проще...

4 стартмани

07.05.2007    32381    2904    CheBurator    64