Очистка истории изменения объектов УПП

19.05.22

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

Описание варианта реализации очистки версий объектов старше определённого периода.

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

Появилась идея не полностью чистить регистр, а просто очищать самую объемную часть - Хранилище значений.

Таким образом, записи остаются с историей изменений, и база сильно не разрастается. Также можно включить историю по всем объектам, не экономя.

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

Процедура ЧисткаВерсийОбъектов() Экспорт

	Запрос = Новый Запрос;
	Запрос.Текст = "ВЫБРАТЬ
	               |	ВерсииОбъектов.Объект,
	               |	ВерсииОбъектов.НомерВерсии,
	               |	ВерсииОбъектов.ДатаВерсии
	               |ИЗ
	               |	РегистрСведений.ВерсииОбъектов КАК ВерсииОбъектов
	               |ГДЕ
	               |	ВерсииОбъектов.ДатаВерсии < &ДатаВерсии
	               |	И НЕ ВерсииОбъектов.ВерсияПроигнорирована
	               |
	               |СГРУППИРОВАТЬ ПО
	               |	ВерсииОбъектов.Объект,
	               |	ВерсииОбъектов.НомерВерсии,
	               |	ВерсииОбъектов.ДатаВерсии
	               |
	               |УПОРЯДОЧИТЬ ПО
	               |	ВерсииОбъектов.ДатаВерсии";
	Запрос.УстановитьПараметр("ДатаВерсии", ДобавитьМесяц(ТекущаяДата(),-7)); //старше пол года. Можете этот параметр получать из константы или настройки любой для возможности менять.
	Выборка = Запрос.Выполнить().Выбрать();
	НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();
	Пока Выборка.Следующий() Цикл
		//Запишем запись в РС
		НаборЗаписей.Отбор.Объект.Установить(Выборка.Объект);
		НаборЗаписей.Отбор.НомерВерсии.Установить(Выборка.НомерВерсии);
		НаборЗаписей.Прочитать();
		НаборЗаписей[0].ВерсияОбъекта = Новый ХранилищеЗначения(Неопределено);
		НаборЗаписей[0].ВерсияПроигнорирована = Истина;
		НаборЗаписей.Записать(Истина);
	КонецЦикла;

КонецПроцедуры

Авось пригодится кому скопипастить...

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

УПП версии объектов чистка базы Управление производственным предприятием код обработка хранилище значений история изменений свёртка

См. также

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

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

24900 руб.

20.08.2024    64694    340    167    

299

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

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

6100 руб.

16.03.2015    280626    253    83    

287

Чистка данных Системный администратор Программист 1С:Предприятие 8 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. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 26.02.2026, версия 4.5, 4.6.0)

14640 руб.

22.02.2013    145919    290    153    

458

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

Решение представляет собой набор из 6 обработок для 1С по удалению организаций и справочников из базы по фильтрам, документов по фильтрам, универсальное сжатие данных, очистка битых движений регистратора, удаление устаревших регистров сведений, удаление устаревших документов "Электронное письмо входящее" и "Электронное письмо исходящее"

23999 руб.

20.02.2026    843    1    0    

4

Чистка данных Программист Пользователь 1С:Предприятие 8 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    30390    82    21    

97

Чистка данных Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

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

5084 руб.

23.08.2021    12383    26    3    

32

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

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

5084 руб.

09.04.2019    31837    48    15    

51
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. dsdred 4220 19.05.22 09:56 Сейчас в теме
Не вводите в заблуждение людей.
История изменений и версионирование это совершенно разные вещи.
2. Goggy 6 19.05.22 14:59 Сейчас в теме
(1) Я даже и не пытался. То, что потом таким же названием начали называть отдельный механизм платформы это не значит что я кого-то ввожу в заблуждение. Скорее вы наводите на меня необоснованную инсинуацию, месье.
А в УПП именно так и называется для пользователя в меню данный типовой механизм конфигурации. Можете убедиться в этом нажав "Сервис" -> "История изменений объектов".
3. dsdred 4220 19.05.22 15:21 Сейчас в теме
(2) УПП вещь старая доступа к ней у меня сейчас нет. В любом случае я уверен что речь идёт о БСП: Версионирование объектов.

Читая заголовок, я сразу думаю про платформенный механизм. Глядя в статью я виже БСП: Версионирование объектов.

РегистрСведений.ВерсииОбъектов
4. AneJIbcuH 39 24.05.22 08:04 Сейчас в теме
"ВерсияПроигнорирована" что значит ? Где ещё используется?
Очищая просто хранилище, нормально уменьшается объем?
5. Goggy 6 24.05.22 20:16 Сейчас в теме
(4) Да нигде по сути, устаревший реквизит. Поэтому в своём случае решил использовать его для отметки уже очищенных позиций.
6. fixin 4335 19.01.26 21:16 Сейчас в теме
Спасибо, пригодилось. Использовал в консоли запроса, правда.
Запрос:
ВЫБРАТЬ //ПЕРВЫЕ 2
   ВерсииОбъектов.Объект,
   ВерсииОбъектов.НомерВерсии,
   ВерсииОбъектов.ДатаВерсии
ИЗ
   РегистрСведений.ВерсииОбъектов КАК ВерсииОбъектов
ГДЕ
   ВерсииОбъектов.ДатаВерсии < &ДатаВерсии
   И НЕ ВерсииОбъектов.ВерсияПроигнорирована

СГРУППИРОВАТЬ ПО
   ВерсииОбъектов.Объект,
   ВерсииОбъектов.НомерВерсии,
   ВерсииОбъектов.ДатаВерсии

УПОРЯДОЧИТЬ ПО
   ВерсииОбъектов.ДатаВерсии
Показать


Код для обработки:
НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();
НаборЗаписей.Отбор.Объект.Установить(Рез.Объект);
НаборЗаписей.Отбор.НомерВерсии.Установить(Рез.НомерВерсии);
НаборЗаписей.Прочитать();
НаборЗаписей[0].ВерсияОбъекта = Новый ХранилищеЗначения(Неопределено);
НаборЗаписей[0].ВерсияПроигнорирована = Истина;
НаборЗаписей.Записать(Истина);
//Сообщить(Рез.Объект);
Показать
Для отправки сообщения требуется регистрация/авторизация