Версионирование объектов 1С сторонними средствами

Публикация № 1176254

Разработка - Инструментарий разработчика - Прочие инструменты разработчика

версия объекта ms sql

В больших информационных системах встает острая необходимость хранения ИСТОРИИ изменений объектов. Она предоставляет материал как для проведения следственных действий, так и для инкрементарного сбора данных в data ware house из 1С конфигураций. Настоящая статья описывает способ версионирования объектов 1С, таких как Документы и Справочники средствами СУБД. Применение такого метода не вызывает рост и фрагментацию основной (рабочей) базы данных (1С) и позволяет сохранять информацию обо всех изменениях, сделанные пользователями.

Хранение версий объектов осуществляется в БД ObjectVersion, расположенной на сервере, желательно (но не обязательно) на том-же, где расположена основная БД.

Строка подключения :

Provider=SQLNCLI11;Server=lpc:(local)\MyINSTANCE;Database=ObjectVersion;Uid=1Cv8Log2;Pwd=Pa$$w0rd;

 

!Внимание. В исходных текстах модулей, приводимых в статье строка подключения загружается из регистра сведений  ВС_ПредопределенныеЭлементы. Такое поведение можно скорректировать следующим образом.

 


//пСтрока_Подключения = РегистрыСведений.ВС_ПредопределенныеЭлементы.ПолучитьЗначениеПоИмени("ObjVersion.ConnectionString");

пСтрока_Подключения = Константы.СтрокаПодключенияКСУБДХраненияВерсииОбъекта.Получить();

 

В конфигурацию 1С встраивается три модуля и подписка на событие хх_ПриЗаписиОбъектаДляВерсионирования.ПриЗаписи. Источником события подписки является СправочникОбъект, ДокументОбъект.  Обработчик расположен в модуле xx_УправлениеВерсионированиемОбъектовСервер. 

 

Процедура ЗафиксироватьВерсиюОбъекта(хОбъект,хСсылка) ЭКСПОРТ
    Перем рез;
    УстановитьПривилегированныйРежим(Истина);
    
    Попытка
        пСтрока_Подключения = РегистрыСведений.ВС_ПредопределенныеЭлементы.ПолучитьЗначениеПоИмени("ObjVersion.ConnectionString");
        Если НЕ ЗначениеЗаполнено(пСтрока_Подключения) ТОгда
            Возврат;
        КонецЕсли;    
        соединение = ВС_УправлениеВерсионированиемОбъектовПовтИсп.м_ADO_Подключить(пСтрока_Подключения);
        Если (соединение <> Неопределено) И (соединение.State = 1) Тогда
            xmlобъект  = СтрЗаменить(хОбъект,"'","''");
            xmlссылка  = хСсылка;
            пользователь = ПараметрыСеанса.ТекущийПользователь;
            пк = ПолучитьТекущийСеансИнформационнойБазы().ИмяКомпьютера;
            бд = ПолучитьИдентификаторБД();
            бдUUID = бд.ХешСумма;
            бдNAME = бд.СтрокаСоединения;
            комманда = "            
            |DECLARE @dbuuid varchar(36);
            |DECLARE @dbname varchar(50);
            |DECLARE @username nvarchar(50);
            |DECLARE @hostname nvarchar(50);
            |DECLARE @ref xml;
            |DECLARE @curobj xml;
            |
            |SELECT 
            |@dbuuid='"+бдUUID+"',
            |@dbname='"+бдNAME+"',
            |@username='"+пользователь+"',
            |@hostname='"+пк+"',
            |@ref='"+xmlссылка+"',
            |@curobj='"+xmlобъект+"'
            |;
            |
            |EXECUTE [DWHSchema].[addObjVersion] 
            |   @dbuuid
            |  ,@dbname
            |  ,@username
            |  ,@ref
            |  ,@curobj
            |  ,@hostname
            |";

            м_ADO_Запрос_Выполнить(соединение,комманда,рез);
            
        КонецЕсли;
    Исключение
        ВыполнитьЗаписьСобытияВЖурналРегистрации(ОписаниеОшибки(),,,пСтрока_Подключения);
    КонецПопытки;
    
КонецПроцедуры    


Как видно из кода, для записи осуществляется вызов хранимой процедуры [DWHSchema].[addObjVersion], расположенной в одной из схем базы данных [ObjectVersion]. 

База данных представляет из себя  хранилище, состоящее из трех файловых групп которые оптимизируются под хранение данных, хранение BLOB и хранения временных данных для предварительной обработки.  В таблицу [DWHSchema].[Versions] попадают первичные данные. С периодичностью настроенной в расписании задания ObjectVersionDiffCalculate (например 1 час) на шаге 1 вызывается хранимая процедура [DWHSchema].[DoBulkDifferent].

 

Эта хранимая процедура осуществляет окончательную обработку данных которая включает сохранение версии объекта в таблицах

[DWHSchema].[VersionsObjectStorage] и [DWHSchema].[VersionsCompress].

 А так же происходит выделение отличий объекта от его предыдущий версии. Эта информация сохраняется в таблице [DWHSchema].[Differents].

Общение с БД ObjectVersion осуществляется через набор встроенных функций и процедур.

 

[DWHSchema].[addObjVersion]

Процедура, регистрирующая версию объекта. Вызывается из подписки 1С ПриЗаписи.

 

 

[DWHSchema].[GetObjVersions]

Функция возвращает список версий объекта. Ей необходимо передать GUID объекта в качестве параметра. Например:

USE [ObjectVersion]

GO

DECLARE @r nvarchar(36) ='e3488ea5-ce4f-11e9-80c4-a4bf01016d51';

SELECT * FROM [DWHSchema].[GetObjVersions] ( @r ,'')

[DWHSchema].[GetObjectDifferents]

Функция возвращает список различий между версиями объекта. Различия рассчитываются по расписанию задания ObjectVersionDiffCalculate.

DECLARE @r nvarchar(36) ='e3488ea5-ce4f-11e9-80c4-a4bf01016d51';

SELECT * FROM [DWHSchema].[GetObjectDifferents] ( @r)

[DWHSchema].[GetDiffObjOnLine]

Функция возвращает различия между двумя версиями одного объекта. Различия рассчитываются налету. В качестве параметров необходимо передать ID версий объекта. Сначала младшую, затем старшую.

SELECT * FROM [DWHSchema].[GetDiffObjOnLine] (12854,32354)

 

Вызовы процедур и функций встроены в конфигурацию в модуле xx_УправлениеВерсионированиемОбъектовСервер. (ЗафиксироватьВерсиюОбъекта, ПолучитьИсториюИзмененийПоССылке, ПолучитьСписокИзмененийТекущейВерсии, ПолучитьСписокИзмененийТекущейВерсииРасчетная).

Для повышения селективности регистрации событий в БД ObjectVersion находится таблица [DWHSchema].[BlackObjectList] и [DWHSchema].[DBCodes]. В таблице [DWHSchema].[BlackObjectList] содержатся записи об объектах 1С, которые необходимо исключить из трассы версий (поле [dont_save_version] = 1).

В таблице [DWHSchema].[DBCodes] перечислены все варианты подключения к 1С. Регистрируются изменения клиентов, у которых строка подключения записана в таблицу и поле [enable] = 0x01. Заполнение таблицы [DWHSchema].[DBCodes] осуществляется автоматически.

 

Изучить историю изменения объекта можно с помощью внешней обработки. Обработка получает данные из выше перечисленных функций модуля и выводит их на форму как показано на рисунке.

 

В настоящий момент система контроля версий используется в конфигурациях 1С:УПП 1.4, 1С:КА 2.3,  1С:Бух 3.0 (Платформа 1C 8.3.10 и выше).  MS SQL 2016 Standart.

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

Наименование Файл Версия Размер
Исходный код модулей конфигурации 1С (3 шт)
.7z 3,98Kb
06.01.20
0
.7z 2.1 3,98Kb Скачать
СУБД: скрипт развертывания базы ObjectVersion
.7z 6,00Kb
06.01.20
0
.7z 2.1 6,00Kb Скачать

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

Избранное Подписка Сортировка: Древо
В этой теме еще нет сообщений.
Оставьте свое сообщение

См. также

Выполнение произвольного кода 1С на управляемых формах

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Россия Абонемент ($m) Прочие инструменты разработчика

Часто при работе в режиме предприятия необходимо выполнить какой-либо код. Для этого необходимо написать внешнюю обработку, а можно воспользоваться нашей обработкой для выполнения произвольного кода в режиме предприятия.

2 стартмани

18.02.2020    244    seregapolygon    0       

​​​​​​​CorelDRAW Graphics Suite 2019 Промо

CorelDRAW – пакет профессиональных инструментов для редактирования фотографий, разработки дизайна, создания макетов страниц и векторных иллюстраций

БСП - Дополнительная обработка - Заполнение объекта - Произвольный алгоритм

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) БСП (Библиотека стандартных подсистем) Прочие инструменты разработчика

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

1 стартмани

13.02.2020    466    duhh    2       

Сдача регламентированной отчетности из программ 1С Промо

Сдача регламентированной отчетности из программ "1С" во все контролирующие органы без выгрузок и загрузок в другие программы. Для групп компаний действуют специальные предложения.

от 1500 руб.

Простая параллельная обработка данных

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Абонемент ($m) Производительность и оптимизация (HighLoad) Прочие инструменты разработчика

Предлагаю способ быстрой параллельной обработки "неких" данных. Методика проста как дважды два. Предварительно подготовленная обработка запускается вручную в нескольких сеансах, и каждый сеанс занимается обработкой своей части (случайного диапазона). Может пригодиться для ускоренной обработки данных. К примеру, необходимо заполнить реквизит большого справочника, заполнение в один поток идёт долго, а сроки поджимают.

1 стартмани

10.02.2020    566    Amadeus007    8       

Базовый курс по управлению ИТ-проектами. Курс проходит с 26 февраля по 22 апреля 2020 года. Промо

Отличительная черта курса - органичное сочетание трех вещей: 1.Теория проектного управления (PMI®+Agile Alliance+Российские ГОСТ+Методологии от 1С); 2. Опыт внедрения продуктов 1С (опыт франчайзи и успешных компаний + тренды Infostart Event и Agile Days); 3. Разбор реальных проблем и рекомендации экспертов по проектам слушателей. Мы будем фиксироваться на тех инструментах, которые реально оказываются полезными в практике руководителей проектов внедрения. Ведущая курса - Мария Темчина.

от 11000 рублей

Очень простая и удобная отладка внешних обработок

Инструменты и обработки Программист Расширение (cfe) v8 v8::УФ 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

Расширение для отладки внешних отчётов и обработок в несколько кликов.

1 стартмани

07.02.2020    1164    11    for_sale    0       

Набор скриптов .bat для автообновления списка баз и версии платформы 1С

Инструменты и обработки Системный администратор Программист Архив с данными v8 1cv8.cf Россия Windows Абонемент ($m) Прочие инструменты разработчика

Автоматическое обновление списка информационных баз 1С, автоматическая установка новой версии платформы на компьютер пользователя.

1 стартмани

23.01.2020    899    4    ManyakRus    3       

Голосование за доклады на INFOSTART MEETUP Kazan - до 25 февраля. Промо

Выбирайте и голосуйте за самые интересные доклады! Лучшие из лучших попадут в окончательную программу казанского митапа. Оставить свой голос можно до 25 февраля 2020 года.

Конструктор запросов при внешнем подключении

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Россия Windows Абонемент ($m) Консоль запросов Прочие инструменты разработчика

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

1 стартмани

23.01.2020    796    2    falcon_wild    1       

INFOSTART MEETUP Kazan. 13 марта 2020 г. Промо

Инфостарт продолжает путешествие по России. Следующая остановка - Казань. Тема мероприятия - управление и технологии автоматизации учета на платформе "1С: Предприятие". Ждем всех: докладчиков и участников! Стоимость участия - 5 500 рублей. Цена действительна до 30.01.2020

5 500

1C и защищенное хранение данных на блокчейне: модуль интеграции от Acryl Platform

Инструменты и обработки Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Защита и шифрование Блокчейн Расширения Прочие инструменты разработчика

Модуль интеграция 1С и блокчейн платформы "Acryl Platform" без использования внешних компонент. Под катом реализация механизмов Base58, Blake2b, Keccak, Curv25519 (the elliptic curve Diffie–Hellman) в подсистеме "Crypt", примеры генерации ключей, адресов, подписи транзакций, запись данных в блокчейн, чтение и восстановление данных из блокчейн. Код открыть. Лицензия MIT.

1 стартмани

21.01.2020    1848    ArtemSerov    9       

Универсальные инструменты 1С

Инструменты и обработки Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Универсальные обработки Прочие инструменты разработчика

Свободно распространяемый набор универсальных обработок и отчетов в виде расширения для разработки и поддержки, которое работает во ВСЕХ видах клиентских приложений и во всех операционных системах, которые поддерживает платформа 1С:Предприятие, кроме мобильных. Консоль запросов - консоль отчетов - консоль кода - редактор объектов базы данных - удаление помеченных объектов - поиск и удаление дублей - редактор констант - консоль заданий - групповая обработка справочников и документов - динамический список - поиск ссылок на объект - регистрация изменений для обмена данными - структура хранения базы - консоль HTTP запросов.

1 стартмани

21.01.2020    10394    181    cprit    70       

Готовые переносы данных из различных конфигураций 1C Промо

Рекомендуем готовые решения для переноса данных из различных конфигураций 1C. C техподдержкой от разработчиков и гарантией от Инфостарт.

Редактор справки 1С

Инструменты и обработки Программист Архив с данными v8 Windows Абонемент ($m) Прочие инструменты разработчика

Конфигурация для разработки справочной информации для конфигураций 1С. Тестировалось на 1С:Предприятие 8.3 (8.3.13.1690). Файловая база.

3 стартмани

16.01.2020    2887    5    lastpioneer    10       

Документация по объектам расширения конфигурации 1С

Инструменты и обработки Программист Архив с данными v8 v8::УФ 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

Обработка для автоматического создания документации для программистов по доработкам в расширении конфигурации.

1 стартмани

14.01.2020    2199    11    ManyakRus    2       

Подборка решений для взаимодействия со ФГИС «Меркурий» Промо

С 1 июля 2019 года все компании, участвующие в обороте товаров животного происхождения, должны перейти на электронную ветеринарную сертификацию (ЭВС) через ФГИС «Меркурий». Инфостарт предлагает подборку программ, связанных с этим изменением.

Неиндексированные измерения регистров сведений. В помощь 1С:Эксперту

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

Обработка показывает неиндексированные измерения регистров сведений, из-за которых случаются блокировки. Для любых баз 1С - на обычных и управляемых формах.

1 стартмани

07.01.2020    3023    12    Rustig    30       

Глобальный поиск и замена в модулях конфигурации

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 1cv8.cf Россия Абонемент ($m) Поиск данных Прочие инструменты разработчика

Зачастую у программиста возникает желание работать с кодом модулей конфигурации средствами встроенного языка: так, как мы сейчас работаем с данными. Как результат реализации данной потребности и родилась данная обработка. Она предназначена для минимизации ручного труда при внесении однотипных изменений в модули конфигурации. Она представляет из себя расширение глобального поиска и замены в конфигураторе. Отличие в предоставлении ряда дополнительных возможностей, таких, как: наложение условий И, ИЛИ, НЕ; поиск только в названии процедуры / функции, либо в теле определенной процедуры / функции; управление поиском в комментариях и др.

1 стартмани

06.01.2020    897    1    keifaya    0       

Новый раздел на Инфостарте - Electronic Software Distribution Промо

Инфостарт напоминает: на нашем сайте можно купить не только ПО, связанное с 1С. В нашем арсенале – ESD-лицензии на ПО от ведущих вендоров: Microsoft, Kaspersky, ESET, Dr.Web, Аскон и другие.

  • Низкие цены, без скрытых платежей и наценок
  • Оперативная отгрузка
  • Возможность оплаты с личного счета (кешбек, обмен стартмани на рубли и т.п.)
  • Покупки идут в накопления для получения скидочных карт лояльности Silver (5%) и Gold (10%)

Подсистема перевода базы данных

Инструменты и обработки Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Прочие инструменты разработчика Локализация решений

В базе данных работают разноязычные пользователи и приходится писать наименования объектов сразу на нескольких языках? ЕСТЬ РЕШЕНИЕ!

2 стартмани

04.01.2020    892    1    onec.developer    0       

Программы для исполнения 488-ФЗ: Маркировка товаров Промо

1 января 2019 года вступил в силу ФЗ от 25.12.2018 № 488-ФЗ о единой информационной системе маркировки товаров с использованием контрольных (идентификационных) знаков, который позволяет проследить движение товара от производителя до конечного потребителя. Инфостарт предлагает подборку программ, связанных с применением 488-ФЗ и маркировкой товаров.

Расширение для отладки внешних печатных форм

Инструменты и обработки Программист Расширение (cfe) v8 v8::УФ 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

При разработке внешних печатных форм иногда возникают проблемы с отладкой. Данное расширение позволяет указать путь к файлу с печатной формой и произвести его отладку через конфигуратор.

1 стартмани

31.12.2019    1157    7    Sergspectr    7       

Генератор форматированной строки (с визуальным редактором)

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

Обработка позволяет создать любую форматированную строку в визуальном редакторе и сгенерировать код её программного создания.

1 стартмани

26.12.2019    2848    5    XilDen    6       

Программы для исполнения 54-ФЗ Промо

С 01.02.2017 контрольно-кассовая техника должна отправлять электронные версии чеков оператору фискальных данных - правила установлены в 54-ФЗ ст.2 п.2. Инфостарт предлагает подборку программ, связанных с применением 54-ФЗ, ККТ и электронных чеков.

FormEditor - поставляемый модуль программного создания элементов форм

Инструменты и обработки Программист Конфигурация (md, cf) v8 Абонемент ($m) Практика программирования Прочие инструменты разработчика

Упрощенное добавление реквизитов формы, добавление их на форму (в том числе и таблиц), также добавление групп, команд формы и кнопок к ним.

1 стартмани

20.12.2019    2490    7    coolo1    10       

1C:Предприятие для программистов: Запросы и отчеты. Второй поток. Онлайн-интенсив с 17 марта по 16 апреля 2020 г. Промо

Данный онлайн-курс предусматривает углубленное изучение языка запросов и возможностей системы компоновки данных, которые понадобятся при разработке отчетов, работающих на платформе “1С:Предприятие” в рамках различных прикладных решений. Курс предназначен для тех, кто уже имеет определенные навыки конфигурирования и программирования в системе “1С:Предприятие”, а также для опытных пользователей различных прикладных решений, которые используют в своей работе отчеты разного назначения.

6500 рублей

Инструментарий для анализа и редактирования регистров 1С (Управляемые формы)

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8::УФ 1cv8.cf Абонемент ($m) Структура метаданных Прочие инструменты разработчика Механизмы бухгалтерского учета Механизмы оперативного учета Расчетные механизмы

Набор инструментов для анализа и манипулирования записями регистров накопления, сведений, бухгалтерии и расчёта. Обладает широким спектром возможностей для отбора и редактирования. Для тех, кто работает с ЕРП.

2 стартмани

17.12.2019    2887    16    Азбука Морзе    16       

1C:Предприятие для программистов: Расчетные задачи (зарплата). Онлайн-интенсив с 01 по 17 июня 2020 г. Промо

Данный онлайн-курс предусматривает изучение механизмов платформы “1С:Предприятие”, которые предназначены для автоматизации периодических расчетов, а именно - для расчета зарплаты. Курс предназначен для тех, кто уже имеет определенные навыки конфигурирования и программирования в системе “1С:Предприятие”, а также для опытных пользователей прикладного решения “1С:Зарплата и управление персоналом” и прочих прикладных решений, в которых реализован функционал расчета зарплаты.

4900 рублей

Сравнение структуры метаданных неограниченного числа конфигураций

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8::УФ 1cv8.cf Windows Абонемент ($m) Прочие инструменты разработчика

Опять слетела часть галочек в подписке на событие при сравнении/объединении с новым типовым релизом? Потеряли новый документ регистратор при переносе в продакшн?

1 стартмани

13.12.2019    1112    6    An-Aleksey    2       

Архив шаблонов: Внешняя печатная форма (клиентский метод), Внешняя печатная форма (серверный метод), Внешний отчет, Внешние дополнительные обработки

Инструменты и обработки Программист Архив с данными v8 v8::УФ 1cv8.cf Абонемент ($m) Прочие инструменты разработчика

Шаблоны подключаемых обработок для управляемых форм. Состав архива 1. Шаблон внешнего отчета на СКД 2. Шаблон дополнительной внешней обработки с открытием формы 3. Шаблон дополнительной внешней обработки без открытия формы (возможно использование в качестве фонового задания) 4. Шаблон внешней печатной формы (серверный метод) 5. Шаблон внешней печатной формы с открытием формы (клиентский метод). 6. Шаблон обработки заполнения документа

2 стартмани

01.12.2019    3264    15    roma_semenov79    0