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

0. 3 17.10.20 08:00 Сейчас в теме
Из-за частого перепроведения документов и включенного версионирования очень разрослась база. Написал обработку, которая удаляет одинаковые версии.

Перейти к публикации

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

Программист 1С
Москва
зарплата от 150 000 руб. до 220 000 руб.
Полный день

1С Программист по 1С:Управление торговлей
Кострома
зарплата от 100 000 руб. до 110 000 руб.
Полный день

Руководитель отдела разработки
Москва
зарплата от 200 000 руб. до 230 000 руб.
Полный день

Программист 1С
Москва
зарплата от 150 000 руб. до 150 000 руб.
Полный день