Простой способ регистрации изменений реквизитов объектов в 1С Предприятии 8.X (делюсь опытом)

15.05.13

Разработка - Механизмы платформы 1С

Потребовалось отслеживать изменения реквизитов справочников, документов (в т.ч. и табличных частях), так как штатный журнал регистрации не даёт достаточной информации. Поскольку внедрять в рабочую конфу какие-то навороченные подсистемы, коих на данном ресурсе и вообще в сети как грязи, не хотелось, решил я сваять небольшую процедуру регистрации изменений в журнале регистрации. Сама идея подобной фичи возникла после прочтения материалов статьи Механизм детального отслеживания изменения содержимого документов http://faq1c.gorbunov.ru/node/1 Что из этого получилось, смотрите ниже.

Добавить в какой-либо общий модуль функцию и процедуру

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

// Универсальная процедура, регистрирующая изменения реквизитов объекта (справочник, документ, план обмена, ПВХ)
// в журнале регистрации
//
Процедура РегистрацияИзмененийРеквизитовОбъекта(Объект) Экспорт
    Перем МетаданныеОбъекта;
    
    Если НЕ Объект.Ссылка.Пустая() Тогда
        
        МетаданныеОбъекта = Объект.Метаданные();
        
        СтрокаСобытие = "Данные.ИзменениеРеквизитов." + МетаданныеОбъекта.Имя;
        ПрежнийОбъект = Объект.Ссылка;
        РеквизитыПрежнегоОбъекта = ПолучитьРеквизитыОбъекта(ПрежнийОбъект);
        
        СтрокаСообщениеРеквизит = "Изменён реквизит ";
        СтрокаСообщениеТабЧасть = "Изменена таб.часть ";
        СтрокаСообщениеТабЧастьУдалено = "Удалено ";
        СтрокаСообщениеТабЧастьДобавлено = "Добавлено ";
        
        Для Каждого Элемент из РеквизитыПрежнегоОбъекта Цикл
            ПрежнийРеквизитЗначение = Элемент.Значение;
            НовыйРеквизитЗначение = Объект[Элемент.Ключ];
            Если ТипЗнч(НовыйРеквизитЗначение) = Тип("Строка") Тогда
                НовыйРеквизитЗначение = СокрЛП(НовыйРеквизитЗначение);
            КонецЕсли;
            Если ТипЗнч(ПрежнийРеквизитЗначение) = Тип("Строка") Тогда
                ПрежнийРеквизитЗначение = СокрЛП(ПрежнийРеквизитЗначение);
            КонецЕсли;
            Если ПрежнийРеквизитЗначение <> НовыйРеквизитЗначение Тогда
                ЗаписьЖурналаРегистрации(СтрокаСобытие, УровеньЖурналаРегистрации.Предупреждение, МетаданныеОбъекта, ПрежнийОбъект, СтрокаСообщениеРеквизит + Элемент.Ключ + Символы.ВК + "Прежний: " + Строка(ПрежнийРеквизитЗначение) + Символы.ВК + "Новый: " + Строка(НовыйРеквизитЗначение));
            КонецЕсли;
        КонецЦикла;
        
        Если МетаданныеОбъекта.ТабличныеЧасти.Количество() > 0 Тогда
            
            // Определяем список проверяемых реквизитов табличных частей,
            // чтобы не забивать журнал регистрации лишними записями.
            // Для каждой конфигурации определить свой список, либо удалить проверку
            // Здесь приведён пример для Управления Торговлей.
            ПроверяемыеРеквизитыТабЧасти = Новый Структура("Номенклатура, ЕдиницаИзмерения, Количество, Цена, Сумма, СтавкаНДС, СерияНоменклатуры, ХарактеристикаНоменклатуры, СерияНоменклатурыНовая, ХарактеристикаНоменклатурыНовая, СерияНоменклатурыСтарая, ХарактеристикаНоменклатурыСтарая, Проект, ЗаказПокупателя, Сделка, ДокументПартии, ДокументРасчетовСКонтрагентом, СуммаВзаиморасчетов, ДоговорКонтрагента, Контрагент, СтатьяДвиженияДенежныхСредств, ПроцентСкидкиНаценки, НаименованиеТовара, ЗаказПоставщику, ДокументПоступления, ДокументОснование, ИсходноеРазмещение, НовоеРазмещение, СуммаТовара, СуммаПлатежа, Размещение, УвеличениеДолгаКонтрагента, УменьшениеДолгаКонтрагента, КоличествоУчет, ДокументРезерва, ТипЦен, Валюта, Пользователь, ВидЗадолженности, ВидОперации");
            
            //This code is ported from http://www.kb.mista.ru/article.php?id=115
            Для Каждого МДТЧ ИЗ МетаданныеОбъекта.ТабличныеЧасти Цикл
                ИмяТЧ = МДТЧ.Имя;
                ТЧ1 = Объект[ИмяТЧ];
                ТЧ2 = ПрежнийОбъект[ИмяТЧ];
                ТЧ1Количество = ТЧ1.Количество();
                ТЧ2Количество = ТЧ2.Количество();
                Если ТЧ1Количество <> ТЧ2Количество Тогда
                    ЗаписьЖурналаРегистрации(СтрокаСобытие, УровеньЖурналаРегистрации.Предупреждение, МетаданныеОбъекта, Объект.Ссылка, СтрокаСообщениеТабЧасть + ИмяТЧ + Символы.ВК + "Прежняя: " + Строка(ТЧ2Количество) + ". Новая: " + Строка(ТЧ1Количество));
                КонецЕсли;
                Если ТЧ1Количество = ТЧ2Количество Тогда
                    СтрокаСообщение = СтрокаСообщениеРеквизит;
                ИначеЕсли ТЧ2Количество > ТЧ1Количество Тогда
                    СтрокаСообщение = СтрокаСообщениеТабЧастьУдалено;
                ИначеЕсли ТЧ2Количество < ТЧ1Количество Тогда
                    СтрокаСообщение = СтрокаСообщениеТабЧастьДобавлено;
                КонецЕсли;
                
                Для Инд = 0 По Макс(ТЧ1Количество - 1, ТЧ2Количество - 1) Цикл
                    
                    Для Каждого МДРТЧ ИЗ МДТЧ.Реквизиты Цикл
                        Реквизит = МДРТЧ.Имя;
                        
                        // При необходимости проверку можно удалить
                        Если НЕ ПроверяемыеРеквизитыТабЧасти.Свойство(Реквизит) Тогда
                            Продолжить;
                        КонецЕсли;
                        
                        Если Инд >= ТЧ1Количество Тогда
                            НовыйРеквизитЗначение = Неопределено;
                        Иначе
                            НовыйРеквизитЗначение = ТЧ1[Инд][Реквизит];
                        КонецЕсли;
                        Если Инд >= ТЧ2Количество Тогда
                            ПрежнийРеквизитЗначение = Неопределено;
                        Иначе
                            ПрежнийРеквизитЗначение = ТЧ2[Инд][Реквизит];
                        КонецЕсли;
                        
                        Если (ЗначениеЗаполнено(ПрежнийРеквизитЗначение) И ЗначениеЗаполнено(НовыйРеквизитЗначение)) ИЛИ (НЕ ЗначениеЗаполнено(ПрежнийРеквизитЗначение) И ЗначениеЗаполнено(НовыйРеквизитЗначение)) ИЛИ (ЗначениеЗаполнено(ПрежнийРеквизитЗначение) И НЕ ЗначениеЗаполнено(НовыйРеквизитЗначение)) Тогда
                            Если ТипЗнч(НовыйРеквизитЗначение) = Тип("Строка") Тогда
                                НовыйРеквизитЗначение = СокрЛП(НовыйРеквизитЗначение);
                            КонецЕсли;
                            Если ТипЗнч(ПрежнийРеквизитЗначение) = Тип("Строка") Тогда
                                ПрежнийРеквизитЗначение = СокрЛП(ПрежнийРеквизитЗначение);
                            КонецЕсли;
                            Если НовыйРеквизитЗначение <> ПрежнийРеквизитЗначение Тогда
                                ЗаписьЖурналаРегистрации(СтрокаСобытие, УровеньЖурналаРегистрации.Предупреждение, МетаданныеОбъекта, Объект.Ссылка, СтрокаСообщение + ИмяТЧ + "." + Реквизит + " в строке " + (Инд + 1) + Символы.ВК + "Прежний: " + Строка(ПрежнийРеквизитЗначение) + Символы.ВК + "Новый: " + Строка(НовыйРеквизитЗначение));
                            КонецЕсли;
                        КонецЕсли;
                        
                    КонецЦикла;
                КонецЦикла;
            КонецЦикла;
        КонецЕсли;
        
    КонецЕсли;
    
КонецПроцедуры

Создать подписку на событие для документов

Источник = ДокументОбъект

Событие = ПередЗаписью

Назначить обработчик события

Процедура ПередЗаписьюДокументаПередЗаписью(Источник, Отказ, РежимЗаписи, РежимПроведения) Экспорт

    //Изменения будем регистрировать для случаев проведения или отмены проведения,
    //так как для простой записи контроль не имеет особого смысла
    Если НЕ Отказ И ((РежимЗаписи = РежимЗаписиДокумента.Проведение) ИЛИ (РежимЗаписи = РежимЗаписиДокумента.ОтменаПроведения)) Тогда
        РегистрацияИзмененийРеквизитовОбъекта(Источник);
    КонецЕсли;

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

Создать подписку на событие для справочников (ПВХ, планов обменов)

Источник = ПланВидовХарактеристикОбъект, ПланОбменаОбъект, СправочникОбъект

Событие = ПередЗаписью

Назначить обработчик события

//Регистрируем изменения для справочника, плана обмена, ПВХ
//
Процедура ПередЗаписьюОбъектаПередЗаписью(Источник, Отказ) Экспорт

    Если НЕ Отказ Тогда
        РегистрацияИзмененийРеквизитовОбъекта(Источник);
    КонецЕсли;

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

Собственно всё. Со вчерашнего дня сие творчество стоит на дежурстве в рабочей конфигурации.

Скриншот результатов работы процедуры в журнале регистрации

См. также

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Эта небольшая статья - некоторого рода шпаргалка по файловым потокам: как и зачем с ними работать, какие преимущества это дает.

23.06.2024    7926    bayselonarrend    20    

156

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    6223    dsdred    18    

80

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Все мы используем массивы в своем коде. Это один из первых объектов, который дают ученикам при прохождении обучения программированию. Но умеем ли мы ими пользоваться? В этой статье я хочу показать все методы массива, а также некоторые фишки в работе с массивами.

24.01.2024    18827    YA_418728146    26    

72

Механизмы платформы 1С Программист Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    24051    SeiOkami    48    

135

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    15109    YA_418728146    7    

169
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mdzen 238 11.05.09 23:31 Сейчас в теме
Интересно.
Как в просмотре журнала это смотрится...
2. Armando 1401 12.05.09 10:07 Сейчас в теме
Да, точно. Автор, покажи картинку.
ps. мне еще вот это понравилось:
//This code is ported from http://www.kb.mista.ru/article.php?id=115
"Кофе энд булочка. Ниче, что я по-английски?" - From a joke
4. Поручик 4693 12.05.09 10:24 Сейчас в теме
(2) :) То, что тебе понравилось, это привычка с модописательства для phpbb
3. Поручик 4693 12.05.09 10:22 Сейчас в теме
Как-то так. http://forum.aeroion.ru/download434.png
Имя пользователя и машины я потёр, что бы не попалить
5. Armando 1401 12.05.09 10:51 Сейчас в теме
(3) Если реквизит был изменен, то хочется видеть на что именно. А то заблудиться можно. Картинку лучше в статью прилепи.
(4) Я так и понял, что привычка. У меня имха, что это как-то нелепо смотрится.

Разукрашенный код намного удобней и приятней смотреть)
6. Armando 1401 12.05.09 10:57 Сейчас в теме
И еще. Если это делается для пользователей, то лучше использовать не идентификаторы объектов, а синонимы.
9. Поручик 4693 12.05.09 11:02 Сейчас в теме
(6) ну тут на каждый чих не наздравствуешься.
7. Поручик 4693 12.05.09 10:59 Сейчас в теме
>> Если реквизит был изменен, то хочется видеть на что именно.
Ну так кликни по строке в журнале и увидишь полную раскладку по данному событию.
8. Armando 1401 12.05.09 11:00 Сейчас в теме
(7) Уже понял. Я просто картинку изучаю))
10. registr 24.05.09 00:02 Сейчас в теме
Полезная вещь.. :) Но я лично, дополнительно решил пойти несколько другим путем - пусть каждый объект еще и сам хранит историю своих изменений, и более подробную...
Motherhubbard; +1 Ответить
11. Поручик 4693 24.05.09 10:25 Сейчас в теме
Если нужна история изменений, да ещё и подробная, да ещё и с восстановлением, вам сюда http://infostart.ru/projects/4040/ или в аналогичные.
12. Поручик 4693 28.05.09 18:04 Сейчас в теме
Немного изменил процедуры. Добавлено обработка отказа и изменения владельца или родителя для элементов справочников.
13. glek 120 09.06.09 17:04 Сейчас в теме
Ну не знаю, насчет журнала регистрации.
1. Учитывая что анонсировано для 8.1, то почему бы не использовать подписку на события? и типового изменения меньше
2. Кто нить пробовал наложить фильтр на журнал регистрации в случае активной работы? И вы еще хотите туда что-то еще добавлять? и как это потом анализировать?
14. glek 120 09.06.09 17:05 Сейчас в теме
сорри, не увиждел про подписку.
15. CheBurator 2712 09.06.09 17:14 Сейчас в теме
блин, на семерке этих разработок - вагон и тележка.. и все на 8-ке тех же клоунов лепим.. хоть бы чего нового...
.
1. отслежтвается программное изменение реквизитов? если нет - в сад!
2. способна прога понять, что изменение порядка строк не является изменением? если нет - в сад!
.. пока хватит..
16. Поручик 4693 15.06.09 13:24 Сейчас в теме
CheBurator, взад
1. Отслеживается. Подписка на событие срабатывает в любом случае. Учи матчасть. В сад.
2. не способна, так как и не требовалось по условиям матча. Остальное пох. опять же ва сад.
Luqe; Aleshin94; AndrewVVS; Cyberboy; viddik; wunderland; +6 1 Ответить
17. ValentinV 17.06.09 20:21 Сейчас в теме
Любопытно.
А пику. Есть ли какие законченные продукты для управления проектами?
Я знаю только: http://v8.1c.ru/solutions/product.jsp?prod_id=32
Уж по деньгам кусаеться.
Надо бы заценить вашу идею.
18. Поручик 4693 19.06.09 12:28 Сейчас в теме
>>>> 2. Кто нить пробовал наложить фильтр на журнал регистрации в случае активной работы? И вы еще хотите туда что-то еще добавлять? и как это потом анализировать?
Кстати для этих целей я внедрил в конфу быстрый журнал регистрации.
http://infostart.ru/projects/3904/
С сабжем добавление не связано.
19. Magister 134 13.07.09 18:30 Сейчас в теме
Завтра в работу пустим, посмотрим как покажет себя ))
Из найденного - не регистрирует изменения для ПВХ и планов счетов, ошибка на строчках:
Если МетаданныеОбъекта.Иерархический ....
И
Если (МетаданныеОбъекта.Владельцы.Количество() .....
Нет для них таких свойств метаданных
20. Поручик 4693 17.07.09 23:29 Сейчас в теме
В этиx cтрoкax дoбaвить уcлoвиe ЭтоСправочник. Будет нopмaльнaя cвязь c ceтью, иcпpaвлю.
21. Magister 134 21.07.09 12:43 Сейчас в теме
(20)
та это понятно, я для себя исправил уже.

да, ещё - не регистрирует изменение констант. мне в принципе не особо надо было, поэтому не дорабатывал - но теоретически было бы неплохо.
22. Поручик 4693 21.07.09 16:49 Сейчас в теме
Случай для справочников исправил. А с константами песня отдельная и потребности такой у нас тоже нет.
23. V1V 112 03.08.09 19:17 Сейчас в теме
Чем не устроил типовой механизм версионирования? Позволяет не только видеть какие реквизиты менялись, что менялось, но также проводит сравнения и откатываться на любую версию. Да и кода многова-то...
24. Поручик 4693 05.08.09 11:25 Сейчас в теме
(23) Версионирование где? В УПП? Есть такое, начиная с релиза 1.2.23

А в других конфах?
Или он, по-твоему, зашит на уровне платформы или появляется по щучьему велению?
25. V1V 112 06.08.09 07:26 Сейчас в теме
(24) А в других "конфах" можно эту идею реализовать с минимальными изменениями. Либо дождаться очередного релиза, благо не долго ждать.
27. artbear 1563 06.08.09 09:32 Сейчас в теме
(25) Совершенно не уверен, что 1С будет подобные "идеи" реализовывать во всех типовых конфах.
Например, ИМХО в БП им это нафиг не нужно, до сих пор механизм полезнейший механизм свойств не добавили :(
В ЗиК-е вполне могут добавить, хотя также очень сомневаюсь.

(23) Кода многовато? ты в УПП-то код версионирования видел? :)
26. Поручик 4693 06.08.09 09:28 Сейчас в теме
Желающие, конечно, могут подождать. Учитывая расторопность 1С
28. Поручик 4693 10.08.09 15:02 Сейчас в теме
Изменений в коде нет.
Поменял только ссылку на источник вдохновения (первоначальная уже не работала).
29. Поручик 4693 07.09.09 21:19 Сейчас в теме
Изменения в коде после одной массовой обработки справочника.
Сделал игнорирование удаления ведущих или ведомых пробелов в строковых реквизитах.
30. SunnyCat 11.09.09 08:02 Сейчас в теме
А как бы еще добавить отслеживание изменений в Регистрах сведений? Ладно те, которые регистраторам подчиняются - в большинстве случаев все изменения можно в документах увидеть, а у нас еще есть такие, куда пользователи ручками изменения вносят - изменения налоговых ставок, вычетов НДФЛ, периодических констант и много чего еще, так вот хотелось бы видеть кто, что и когда внес, изменил. По аналогии сделать не удалось - в событиях ПриЗаписи и Запись есть только Отказ и Замещения, сами данные-то не передаются. Киньте идею как реализовать, чтобы данные так же заносились в журнал регистрации? (конфа зарплатная, не типовая, написана на заказ)
31. artbear 1563 30.01.10 08:25 Сейчас в теме
При использовании этой схемы в 8.1.15/14 мои пользователи стали жаловаться на постоянные блокировки
Причем система до этого работала не один месяц, проблемы с блокировками были незаметны.
В результате анализа выяснил, что ошибка в использовании объектного подхода - типа ПрежнийОбъект.Номер
А прежний объект - это ведь ссылка, и идет получение инфы из базы.
Перевел код на использование запросов, блокировки исчезли.
32. Поручик 4693 31.01.10 02:36 Сейчас в теме
(31) Значит, мне ещё везёт, сам таких жалоб не слышал. Будет время, займусь переписыванием.
33. artbear 1563 31.01.10 10:20 Сейчас в теме
(32) Могу выложить готовый код.
В мыло или в личку или в аську.
34. Поручик 4693 31.01.10 18:18 Сейчас в теме
(33) Кинь в личку, завтра может помозгую.
Как раз собираюсь конфу обновлять.
35. Поручик 4693 23.07.10 00:21 Сейчас в теме
Не знаю, кому это ещё нужно, но выложил обновлённый вариант с чтением реквизитов запросом.
Sladosya; ben19791010; sound; GIO; +4 Ответить
38. sound 536 10.03.11 15:16 Сейчас в теме
(35) Мне надо. То есть тут не последняя версия?
39. Поручик 4693 10.03.11 15:21 Сейчас в теме
(38) Это и есть последняя версия. Та, которую протестил в прежней конторе, перед выпиливанием оттуда.
40. sound 536 10.03.11 15:24 Сейчас в теме
(39) А все .. понял, сорри, не увидел что текст запроса кусками формируется
PS блин так неудобно стало когда обработку от обсуждения отделили...
36. Yasen 490 23.07.10 07:46 Сейчас в теме
Идея хороша, но изнутри транзакции проведения документа писать лишнее в журнал регистрации - не айс. Это далеко не самый быстрый объект.
Лучше накапливать изменения и записывать их в журнал после того как зафиксирована транзакция и освобождены все блокировки
37. Поручик 4693 23.07.10 12:32 Сейчас в теме
Не спорю, но заморачиваться уже нет особого желания и времени.
41. Vovanich 30.10.11 18:31 Сейчас в теме
Тема актуальная.Кстати в какой модуль это прикручивать?
42. Поручик 4693 30.10.11 18:35 Сейчас в теме
(41) Расскажу за деньги, если читать не умеешь.
43. Vovanich 30.10.11 18:42 Сейчас в теме
Спасиба почитал повнимательнее в том числе код.)))
44. seandr 17.11.11 09:20 Сейчас в теме
Очень простое и гибкое решение... нечто подобное для 7-ки делал в свое время, правда без подписок на событие естетственно ))). По поводу блокировок - ни я ни пользователи не заметили проблем.
45. Поручик 4693 17.11.11 09:31 Сейчас в теме
(44) Как эту статью вижу, так сразу вспоминаю контору, в которой тогда работал. Не от хорошей жизни пришлось выдумывать и прикручивать.
46. wwizard 7 13.03.12 13:29 Сейчас в теме
Пожалуйста подскажите тому кто не понимает, а очень надо: в каком документе/модуле это все надо дописать?
47. Поручик 4693 13.03.12 14:56 Сейчас в теме
(46) Обратитесь лучше к специалисту, не то донаписываете.
48. Kaniman 03.08.12 11:14 Сейчас в теме
Спасибо! особенно, что просто приведен код для вставки в конфигурацию. То, что надо!
49. Люпин 10 15.08.12 16:15 Сейчас в теме
Статья супер! Очень пригодилось! Спасибо огромное автору!
50. Поручик 4693 15.08.12 22:09 Сейчас в теме
Кстати говоря, на 8.2 в режиме управляемого приложения, приведенный код будет исполняться на клиенте. В 8.1. с этим в порядке, исполнение идёт на сервере.
51. StepByStep 3687 17.12.12 22:33 Сейчас в теме
В 8.2 в управляемом приложении в ряде конфигураций появилась сущность "блокируемые реквизиты", т.е. реквизиты, которые нельзя/не рекомендуется изменять после того, как "элементы" (типа Справочника, ПВХ) используются в документах.
52. FlyLink 29.03.13 12:54 Сейчас в теме
53. Поручик 4693 03.06.13 13:52 Сейчас в теме
Что-то волна пошла. Это поделие ещё кому-то интересно?
54. logarifm 1123 03.06.13 14:13 Сейчас в теме
Из этого всего страдает самое важное - ПРОИЗВОДИТЕЛЬНОСТЬ!!!

ИМХО - надо использоввать ПОДСИСТЕМУ "Версионирование" предложенною самой 1С.
Silenser; +1 Ответить
55. echo77 1908 03.06.13 18:16 Сейчас в теме
(54) Надо, только её нет в БП, УТ, и куче других не топовых типовых :-)
56. ixijixi 1922 04.06.13 09:48 Сейчас в теме
Я, пожалуй, попробую запилить в свою конфу, посмотрим, как дело пойдет =)
57. ixijixi 1922 04.06.13 10:59 Сейчас в теме
Запилил, все работает! Спасибо большое, а то админы давно просили. Единственное, что я добавил, так это возможность вкл/выкл возможность записи в журнал регистрации по значению константы "Вести дополнительный журнал регистрации", мало ли тормоза нарисуются в будущем. А так респект!
58. ixijixi 1922 04.06.13 11:11 Сейчас в теме
И да, реально не хватает контроля записи в РС, например Контактная информация или Ответственные лица. Как бы реализовать, нет мыслей?
60. xzorkiix 35 06.06.13 19:21 Сейчас в теме
(58) the1, Подпись на события перед записью не предлагать? (в рамках обсуждаемого решения)

см. справку по РегистрСведенийНаборЗаписей
метод Метаданные() у объекта есть, см. Имя Регистра, определяем нужно ли по нему вести историю
Отбор - доступен, через него можно же получить текущее состояние ИБ
Сравнить Источник и Текущее состояние в ИБ.
59. webester 26 05.06.13 08:35 Сейчас в теме
Получилось неплохо. Я тоже сделал но мой код все таки немного хуже оказался, может даже заберу твой, зафигачу к себе после обработки напильником. Кароч, жирный "+", жаль нельзя два поставить.
61. MartyNSK 1 18.06.13 17:45 Сейчас в теме
Буду пробовать у себя в конфе, спасибо за инфу!
62. timm00 142 19.06.13 01:12 Сейчас в теме
Сделано "для себя") подправить?
63. Al-X 20.06.13 15:34 Сейчас в теме
Спасибо. Внедряю у себя...
64. Поручик 4693 23.06.13 00:42 Сейчас в теме
Просто удивительно, насколько популярным и востребованным даже спустя четыре года оказалось это поделие.
65. Aleksey.z 42 26.06.13 11:24 Сейчас в теме
(64) Да вот все ждем когда 1С займется средой разработки. Давно пора журнал регистрации вести в СУБД и серьезно его доработать.
66. Silenser 612 26.06.13 12:15 Сейчас в теме
Решение интересное, но с оговоркой, для больших баз лучше использовать подсистему версионирования из БСП.
В типовом варианте сериализация в XML и сохранение в регистр работать будет значительно быстрее, а значит вероятность получить дедлок существенно меньше, т.к. в обоих случаях работаем в рамках транзакции записи.
67. ixijixi 1922 14.08.13 17:15 Сейчас в теме
Вываливается в ошибку в серверном варианте работы базы "Попытка передачи мутабельного значения с клиента на сервер", т.к. подписка на события находится в общем модуле Клиент (обычное приложение) и Сервер, а регистрация изменений происходит в ОМ Сервер. Что бы такого лучше сделать?
68. Поручик 4693 14.08.13 19:02 Сейчас в теме
(67) Внимательно прочитать тему и снять флажок сервер с модуля.
69. ixijixi 1922 15.08.13 09:35 Сейчас в теме
(68) внимательно прочитал еще раз

Добавить в какой-либо общий модуль функцию и процедуру

добавил

флажок сервер с модуля

а вот это не катит, иначе как у меня будет работать модуль, если его вообще нЕоткуда вызвать?!

Может, подписки и регистрацию изменений разместить в одном модуле?
70. Поручик 4693 15.08.13 09:44 Сейчас в теме
(69) 300 рублей и займусь вашей проблемой.
71. ixijixi 1922 15.08.13 10:07 Сейчас в теме
(69) Таки добавил в один модуль, вроде все работает. Буду тестить...

(70) Думаю, сам разберусь ;)
72. ab471vi 1 16.09.13 06:20 Сейчас в теме
Спасибо, мне очень пригодилось на управляемых формах!!!
73. adream77 04.03.14 12:07 Сейчас в теме
Понравилось, попробую по возможности.
Прикрепленные файлы:
74. MaximKor 20 06.05.17 17:49 Сейчас в теме
Спасибо за статью! Очень пригодилась!
75. user730384 06.05.17 18:04 Сейчас в теме
76. masik777 02.08.20 11:00 Сейчас в теме
Все здорово, конечно. Но вот понадобилось поставить на УТ 10.3 ( 33.1)
и хотел спросить, заработает ли? Ну или помочь за денежку)) Сергей, ты же писал, что если не за бесплатно, то поможешь)
77. Поручик 4693 20.08.20 16:54 Сейчас в теме
(76) Для УТ 10.3 делалось. Проблема в чём?
Оставьте свое сообщение