Внедрение истории данных

11.06.21

База данных - Журнал регистрации

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

Скачать исходный код

Наименование Файл Версия Размер
 УправлениеИОчисткаИсторииДанных.epf :
.epf 8,08Kb
1
.epf 8,08Kb 1 Скачать

1. Начальное заполнение истории по всем данным нерационально, предлагается вместо этого выполнять запись в историю только при первом изменений объекта. 

2. Если объект сохраняется при отсутствии изменений, тогда прсто выполняем отказ от записи. Объект для сравнения объекта записывается в регистр сведения для временного хранения данных.

3. Обновление истории в ФормаИсторииИзмененийИсторииДанных отключаем и выполняем обновление через регламентное задание.

4. Для скачивания размещена  обработка УправлениеИОчисткаИсторииДанных.epf позволяет управлять механизмом истории в режиме 1С Предприятии. Полезно для включения/отключать механизм истории данных, очистки истории. Полезно также для отключения историии в подчиненных узлах РИБ (если этот механизм не нужен).

Проверено на платформе 1С:Предприятие 8.3 (8.3.13.1809).

Для примера запись истории для справочника (используется подписка на события):
 

// Вставляем в подписку на события: Справочник Объект, ПередЗаписью
Процедура Справочники_ПередЗаписью(Источник, Отказ) Экспорт
    Попытка
        Если Источник.Метаданные().ИсторияДанных =Метаданные.СвойстваОбъектов.ИспользованиеИсторииДанных.Использовать Тогда
            Настройки = ИсторияДанных.ПолучитьНастройки(Источник.Метаданные());
            Если Настройки = Неопределено Тогда
                Использование=Истина;
            Иначе
                Использование=Настройки.Использование;
            КонецЕсли;
            Если НЕ Источник.ЭтоНовый () И НЕ Отказ И Использование Тогда
                ЗаписьJSON = Новый ЗаписьJSON;
                ЗаписьJSON.УстановитьСтроку();
                СериализаторXDTO.ЗаписатьJSON(ЗаписьJSON, Источник.Ссылка.ПолучитьОбъект(), НазначениеТипаXML.Явное);
                СериализованныйОбъект=ЗаписьJSON.Закрыть();    
                
                ЗапРег=РегистрыСведений.ОбъектВХранилище.СоздатьМенеджерЗаписи();
                ЗапРег.СсылкаОбъекта=Источник.Ссылка;
                ЗапРег.ОбъектВХранилище=Новый ХранилищеЗначения(СериализованныйОбъект);
                ЗапРег.Записать();
                
                Отбор = Новый Структура;
                Отбор.Вставить(    "Данные", Источник.Ссылка);
                Версии = ИсторияДанных.ВыбратьВерсии(Отбор,    "НомерВерсии, Дата",,1);
                
                Если Версии.Количество()=0 Тогда
                    ТекущийПользовательИБ=ПользователиИнформационнойБазы.ТекущийПользователь();
                    
                    ЗапРег=РегистрыСведений.РегистрацияВерсииИсторииДанных.СоздатьМенеджерЗаписи();
                    ЗапРег.СсылкаОбъекта=Источник.Ссылка;
                    ЗапРег.ОбъектВХранилище=Новый ХранилищеЗначения(СериализованныйОбъект);
                    ЗапРег.Дата=ТекущаяДата();
                    ЗапРег.ВидИзмененияДанных=Строка(ВидИзмененияДанных.Добавление);
                    ЗапРег.Комментарий="Начальное заполнение истории данных";
                    ЗапРег.ТекущийПользователь=Новый ХранилищеЗначения (ТекущийПользовательИБ);
                    ЗапРег.Записать();                     
                КонецЕсли;
            Иначе
                Если  НЕ Отказ Тогда
                    
                КонецЕсли;
            КонецЕсли;
            
        КонецЕсли;
    Исключение
        Сообщить ( ОписаниеОшибки());    
    КонецПопытки;
    
КонецПроцедуры

// Вставляем в подписку на события: Справочник Объект, ПриЗаписи
Процедура Справочники_ПриЗаписи(Источник, Отказ) Экспорт
    
    Попытка         
        Если  Источник.Метаданные().ИсторияДанных =Метаданные.СвойстваОбъектов.ИспользованиеИсторииДанных.Использовать Тогда
            
            Настройки = ИсторияДанных.ПолучитьНастройки(Источник.Метаданные());
            Если Настройки = Неопределено Тогда
                Использование=Истина;
            Иначе
                Использование=Настройки.Использование;
            КонецЕсли;
            
            Если НЕ Источник.ЭтоНовый () И НЕ Отказ И Использование Тогда
                ЗапРег=РегистрыСведений.ОбъектВХранилище.Получить( Новый Структура("СсылкаОбъекта",Источник.Ссылка));
                ЗапРег=РегистрыСведений.ОбъектВХранилище.СоздатьМенеджерЗаписи();
                ЗапРег.СсылкаОбъекта= Источник.Ссылка;
                ЗапРег.Прочитать();
                
                Если ЗапРег.Выбран() Тогда
                    ОбъектПередЗаписью =ЗапРег.ОбъектВХранилище.Получить();
                    ЗаписьJSON = Новый ЗаписьJSON;
                    ЗаписьJSON.УстановитьСтроку();
                    СериализаторXDTO.ЗаписатьJSON(ЗаписьJSON, Источник, НазначениеТипаXML.Явное);
                    ОбъектПриЗаписи=ЗаписьJSON.Закрыть();
                    
                    СравнениеСтр= Новый СравнениеЗначений  ;
                    Если СравнениеСтр.Сравнить(ОбъектПередЗаписью, ОбъектПриЗаписи)= 0 Тогда 
                        Отказ=Истина;
                    КонецЕсли; 
                    ЗапРег.ОбъектВХранилище= Неопределено;
                    ЗапРег.Удалить();
                Иначе
                    Источник.УстановитьКомментарийВерсииИсторииДанных("создание нового объекта");
                КонецЕсли;
                
            КонецЕсли;
        Иначе
            Если  НЕ Отказ Тогда
                    //Источник.УстановитьКомментарийВерсииИсторииДанных("новый объект");
            КонецЕсли;
        КонецЕсли;
    Исключение
        Сообщить ( ОписаниеОшибки());    
    КонецПопытки;
КонецПроцедуры

//Процедуроа стандартной формы ФормаИсторииИзмененийИсторииДанных
&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
    Перем МетаданныеДанных, ЭтоПодчиненныйРегистрСведений;
    МетаданныеДанных = Параметры.Данные.Метаданные();
    Если Не ПравоДоступа("ПросмотрИсторииДанных", МетаданныеДанных) Тогда
        Отказ = Истина;
        Возврат;
    КонецЕсли;
    Отбор.Вставить("Данные", Параметры.Данные);
    
    Элементы.ВерсииКомментарий.ТолькоПросмотр = Не ПравоДоступа("РедактированиеКомментарияВерсииИсторииДанных", МетаданныеДанных);
    
    ЭтоПодчиненныйРегистрСведений = Метаданные.РегистрыСведений.Содержит(МетаданныеДанных) 
        И МетаданныеДанных.РежимЗаписи = Метаданные.СвойстваОбъектов.РежимЗаписиРегистра.ПодчинениеРегистратору;
        
    Если ЭтоПодчиненныйРегистрСведений 
        Или Не ПравоДоступа("ПереходНаВерсиюИсторииДанных", МетаданныеДанных) Тогда
        Элементы.ФормаПерейтиНаВерсию.Видимость = Ложь;
        Элементы.ВерсииКонтекстноеМенюПерейтиНаВерсию.Видимость = Ложь;
    КонецЕсли;
    
    Заголовок = 
        ПолучитьПредставлениеДанных(МетаданныеДанных, Параметры.Данные) +  " (" + 
        NStr("ru = 'История изменений'; SYS = 'DataHistory.VersionsTitle'", "ru")
         + ")";        
    //ИсторияДанных.ОбновитьИсторию(Параметры.Данные);
    ВыбратьВерсии();
    ОбновитьДоступностьОтключенияОтбора();
    КоманднаяПанель.ПодчиненныеЭлементы.ФормаОбновитьРучками.Видимость= РольДоступна("ПолныеПрава");
КонецПроцедуры

 

См. также

Журнал изменений с восстановлением состояния ссылочных объектов и архивацией по HTTP / COM (расширение + конфигурация, 8.3.14+, ЛЮБАЯ конфигурация)

Архивирование (backup) Журнал регистрации Поиск данных Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 1С:Управление торговлей 11 Платные (руб)

База данных «сама» меняет данные в документах/справочниках? Тогда данный журнал изменений для Вас! Практически не влияет на скорость записи объектов за счет быстрого алгоритма! Скорость работы почти в 2 раза выше типового механизма "История изменений"! Позволяет следить за изменениями и удалением в любых ссылочных объектах конфигурации, с возможностью архивации по HTTP(!) или COM, и сверткой данных. А так же, может восстановить состояние реквизитов (значения) до момента изменения или удаления объекта из базы. Есть ДЕМО-база где можно самостоятельно протестировать часть функционала! Работает на любых платформах выше 8.3.14+ и любых конфигурациях! Версия 3.1 от 24.08.2023!

21600 руб.

15.05.2017    42678    10    24    

38

Версионирование объектов для Альфа-авто, ред 4 и 5.

Оптовая торговля Розничная торговля Журнал регистрации Платформа 1С v8.3 Конфигурации 1cv8 Автомобили, автосервисы Управленческий учет Платные (руб)

Подсистема версионирования объектов для конфигураций Рарус: Альфа-авто на базе типовой подсистемы от 1С. Позволяет хранить историю изменений документов и справочников, кто, что, когда и какие данные изменял, а так же вернуться к предыдущим версиям объекта.

4800 руб.

03.09.2016    42342    33    24    

38

LogManager - Внешний журнал регистрации в SQL

Журнал регистрации Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Журнал регистрации платформы 1С в SQL. Общая база хранения всех журналов. Через com-подключение регламентным заданием периодически догружает журналы регистраций из рабочих баз. Предоставляет настраиваемый доступ к журналам по правам подразделений. Формирует отчеты по пользователям и данным.

10000 руб.

23.05.2014    55632    52    16    

47

Мониторинг баз и серверов 1С

Журнал регистрации Мониторинг Платформа 1С v8.3 Платные (руб)

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

9000 руб.

28.08.2019    31223    14    21    

66

LogiCH - хранение и анализ журнала регистрации в сверхбыстрой СУБД ClickHouse

Журнал регистрации Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Конфигурация LogiCH эффективно решает проблему хранения и анализа записей журналов регистрации. Разработка использует столбцовую СУБД ClickHouse, одну из самых быстрых Big Data OLAP СУБД. Любой анализ журнала можно выполнить в одном отчете, в котором доступны все возможности СКД с учетом ограничений RLS. Количество подключаемых баз не ограничено и не влияет на скорость построения анализа.

5000 руб.

28.11.2018    19663    16    6    

37

Регламентное сокращение журнала регистрации

Инструменты администратора БД Журнал регистрации Платформа 1С v8.3 1С:Управление торговлей 11 Абонемент ($m)

Внешняя обработка для регламентного сокращения журнала регистрации для конфигураций на базе БСП и платформы 8.3.20+

1 стартмани

29.12.2023    1420    16    dima_gsv    1    

12

Магия преобразований: ЖР, ТЖ, RAS/RAC, логи - универсальное решение Vector

Мониторинг Журнал регистрации Технологический журнал Абонемент ($m)

Как легко и быстро с помощью специализированных решений собирать, парсить и передавать логи и метрики.

1 стартмани

13.11.2023    3220    4    AlexSTAL    0    

43

Мониторинг состояния с отправкой в telegram

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

Внешняя обработка для БСП-конфигураций с простым программным интерфейсом. Предназначена для мониторинга состояния системы. Базово реализована отправка ошибок из журнала регистрации, но можно легко добавить мониторинг других журналов, каких-либо действий пользователей, состояния системы (например закрытие месяца).

3 стартмани

26.09.2023    1857    11    doom2good    10    

13
Оставьте свое сообщение