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

29.10.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С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

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

15500 руб.

02.09.2020    222544    1212    415    

1062

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

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

14400 руб.

20.08.2024    45740    251    129    

232

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

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

22200 руб.

06.10.2023    28456    76    30    

101

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

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

9900 руб.

25.08.2025    18567    37    7    

47

Инструментарий разработчика Программист 1С v8.3 Платные (руб)

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

9500 руб.

17.05.2024    40505    148    57    

184

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

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

16000 руб.

10.11.2023    20111    77    39    

92

Перенос данных 1C Оптовая торговля Свертка базы Системный администратор Программист Бухгалтер 1С v8.3 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Хотите точно знать, что вы выгружаете? Хотите сворачивать товары по НДС или фильтровать товары по доп. реквизиту? Вы волшебник, которому необходимо превращать одних контрагентов в других? Хотите при выгрузке превратить группу товаров в один? Или просто нужен удобный OLE обмен между 1C:Управление торговлей (ред. 11 или 10) и 1С:Бухгалтерия предприятия (ред. 2 или 3). Тогда эта обработка для вас!

12900 руб.

19.04.2013    177495    381    400    

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