Переходим с платформенного механизма История данных на механизм Версионирование объектов БСП

13.11.25

База данных - Свертка базы

Данная миграция будет полезна тем, кто имеет самописку на БСП и хочет её свернуть, а версии хранит с помощью платформенного механизма История данных. Свёртка базы не позволяет сворачивать данные таблицы. Так же на версиях платформы ниже, чем 8.3.25 наблюдаются баги поведения указанного механизма.

Файлы

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

Наименование Скачано Купить файл
Переходим с платформенного механизма История данных на механизм Версионирование объектов БСП
.epf 12,59Kb
1 2 150 руб. Купить

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

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

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

У каждого из указанных в наименовании механизмов есть свои плюсы и минусы. Данная обработка подойдет для разработчиков 1С, перед которыми стоит задача уменьшить размер БД всеми возможными способами и как можно сильнее. В рамках этой задачи можно порезать историю данных, для чего её необходимо сначала перевести в метаданные БСП.

Первый нюанс: не все виды метаданных можно хранить в БСП.

Функция ПоддержваемыеВидыМетаданных()
	
	ВидыМетаданных = Новый Массив;
	ВидыМетаданных.Добавить("Справочники");
	ВидыМетаданных.Добавить("Документы");
	ВидыМетаданных.Добавить("ПланыВидовХарактеристик");
	ВидыМетаданных.Добавить("ПланыСчетов");
	ВидыМетаданных.Добавить("ПланыВидовРасчета");
	ВидыМетаданных.Добавить("БизнесПроцессы");
	ВидыМетаданных.Добавить("Задачи");
	
	Возврат ВидыМетаданных;
	
КонецФункции

Второй нюанс: для быстрой работы с версиями истории данных необходимо сначала её обновить.

Процедура ОбновитьИсториюТаблицы(ТекущиеМетаданные)
	
	ИсторияДанных.ОбновитьИсторию(ОбщегоНазначенияКлиентСервер.ЗначениеВМассиве(ТекущиеМетаданные));
	
КонецПроцедуры

После чего внутри каждого вида метаданных обходим каждую таблицу, внутри которой обходим каждый объект, внутри которого обходим все версии по возрастанию... Мёд на глазах от вложенных циклов, но иначе никак :)

Для каждого объекта мы

1. очищаем версии в механизме БСП

2. переносим версии объекта

3. очищаем историю данных по указанному объекту

Процедура ОбработатьТекущиеДанные(Данные, Версии, СоответствиеПользователей)
	
	ОчиститьВерсииБСП(Данные);
	ПеренестиВерсии(Версии, СоответствиеПользователей);
	ОчиститьВерсииИсторииДанных(Данные);
	
КонецПроцедуры

Процедура ОчиститьВерсииБСП(Данные)
	
	Набор = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();
	Набор.Отбор.Объект.Установить(Данные);
	Набор.Записать();
	
КонецПроцедуры

Процедура ПеренестиВерсии(Версии, СоответствиеПользователей)
	
	Для Каждого ТекущаяВерсия Из Версии Цикл
		ПеренестиВерсию(ТекущаяВерсия, СоответствиеПользователей);
	КонецЦикла;
	
КонецПроцедуры

Процедура ОчиститьВерсииИсторииДанных(Данные)
	
	ИсторияДанных.УдалитьВерсии(Данные);
	
КонецПроцедуры

Ну и непосредственная реализация переноса версий:

Процедура ПеренестиВерсии(Версии, СоответствиеПользователей)
	
	Для Каждого ТекущаяВерсия Из Версии Цикл
		ПеренестиВерсию(ТекущаяВерсия, СоответствиеПользователей);
	КонецЦикла;
	
КонецПроцедуры

Процедура ПеренестиВерсию(Версия, СоответствиеПользователей)
	
	ВерсияОбъекта = ИсторияДанных.СформироватьПоВерсии(Версия.Данные, Версия.НомерВерсии);
	
	СведенияОВерсииОбъекта = НовыеСведенияОВерсииОбъекта();
	ЗаполнитьЗначенияСвойств(СведенияОВерсииОбъекта, Версия);
	СведенияОВерсииОбъекта.АвторВерсии = СоответствиеПользователей.Получить(Версия.ИмяПользователя);
	СведенияОВерсииОбъекта.ДатаВерсии = Версия.Дата;
	
	// указываете любой план обмена, в составе которого отсутствует РС ВерсииОбъектов
	ИмяПланаОбмена = "СинхронизацияДанныхЧерезУниверсальныйФормат";
	ВерсионированиеОбъектов.СоздатьВерсиюОбъектаПоОбменуДанными(ВерсияОбъекта, СведенияОВерсииОбъекта, Истина,
		ПланыОбмена[ИмяПланаОбмена].ЭтотУзел()); 
	
КонецПроцедуры

А зачем использовать обмен данными? А затем, что иного способа, где я могу заполнить версию произвольным способом, программный интерфейс версионирования объектов БСП не поддерживает. Поэтому если в Вашей конфигурации нет плана обмена СинхронизацияДанныхЧерезУниверсальныйФормат, можете выбрать любой, где в состав не входит регистр сведений ВерсииОбъектов.

Тестировал обработку на БСП 3.1.6.437. Можно использовать как интерактивно, так и в фоне (поддержана регистрация внешней обработкой).

Итоги: Фирма 1С предусмотрела переход с БСП на историю данных, а обратного перехода не предусмотрели, что и заставило меня разработать данный механизм своими силами. В холиваре, что лучше История данных или Версионирование БСП, не участвую. Каждому выгодно что-то своё. О разнице между механизмами можете почитать тут.

Проверено на следующих конфигурациях и релизах:

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.6.437

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

Обработка БСП Версионирование История данных Внешняя обработка Перенос данных

См. также

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

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

24900 руб.

20.08.2024    52129    291    145    

264

SALE! %

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С:Предприятие 8 Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

16500 15500 руб.

02.09.2020    231177    1259    415    

1088

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    28522    66    12    

74

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С:Предприятие 8 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Библиотека стандартных подсистем Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    31024    81    30    

106

SALE! %

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

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

17000 16000 руб.

10.11.2023    21488    84    42    

96

Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9500 руб.

17.05.2024    44283    156    63    

196

Свертка базы 1С:Предприятие 8 1С:Бухгалтерия 3.0 Россия Платные (руб)

Расширение позволяет за 1-2 дня свернуть информационную базу 1С Бухгалтерии 3.0 с десятками миллионов документов. Использует оптимизированный алгоритм определения документов, на которые нет ссылок, для последующего удаления 16 фоновыми заданиями. Не помечает документы на удаление.

43200 руб.

08.02.2024    2945    7    1    

7
Для отправки сообщения требуется регистрация/авторизация