Регистрация изменений для обмена данными запросом

21.08.23

Интеграция - Обмен между базами 1C

В статье описывается способ, позволяющий регистрировать объекты для обмена при помощи запроса, посредством модернизации типовой обработки "Регистрация изменений для обмена данными", и прилагается эта модернизированная типовая обработка.

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

Наименование Файл Версия Размер
Регистрация изменений для обмена данными МД v1.0:
.epf 142,42Kb
10
.epf 142,42Kb 10 Скачать

При возникновении необходимости перевыгрузить типовым обменом список документов или элементов справочника, добавление на выгрузку нужных объектов при помощи типовой обработки "Регистрация изменений для обмена данными" создаёт неудобства ввиду того, что параметр отбора типа список нельзя просто скопировать и вставить, а нужно добавлять каждый элемент списка вручную.

Столкнувшись с подобной задачей, мне не удалось зарегистрировать изменения для обмена посредством процедуры "МеханизмРегистрацииОбъектовПередЗаписьюДокумента" общего модуля "ОбменДаннымиСобытия", который используется подпиской на событие "ПередЗаписью" у типовых объектов конфигурации, участвующих в обмене.

Код, представленный ниже - не "взлетел".

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

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

Суть доработки - это добавить возможность отбора запросом на форму обработки "ВыборОбъектовОтбором", На эту форму была добавлена Группа страницы, типовые элементы перенесены на страницу "СтраницаОтбор" и создана страница "СтраницаОтборЗапросом", также на форму были добавлены реквизиты "ТекстЗапроса" и "Список", и команда "КомандаВыбратьЗапросом".

 

 

За основу для написания логики обработчика команды "КомандаВыбратьЗапросом" была взята типовая процедура "ПроизвестиВыбор".

&НаКлиенте
Процедура КомандаВыбратьЗапросом(Команда)
	
	Перем ВыборкаДанных, Ссылка;
	
	ВыборкаДанных = КомандаВыбратьЗапросом_НаСервере();
	
	СтруктураПараметров = Новый Структура();
	СтруктураПараметров.Вставить("ИмяТаблицы", Параметры.ИмяТаблицы);
	СтруктураПараметров.Вставить("ДанныеВыбора", ВыборкаДанных);
	СтруктураПараметров.Вставить("ДействиеВыбора", Параметры.ДействиеВыбора);
	СтруктураПараметров.Вставить("СтруктураПолей", СтруктураДанных);
	ОповеститьОВыборе(СтруктураПараметров);
	
КонецПроцедуры

&НаСервере
Функция КомандаВыбратьЗапросом_НаСервере()
	
	Перем Запрос, Выборка, ВыборкаДанных, ТабДок, Сч, ВГраница, мСписок;

	мСписок = Новый Массив();
	
	ТабДок = ЭтаФорма.Список;
	ВГраница = ТабДок.ВысотаТаблицы;

	Для Сч = 2 По ВГраница Цикл
		
		Значение = СокрЛП(ТабДок.Область("R" + Формат(Сч, "ЧГ=0") + "C1").Текст);
		
		Если НЕ ЗначениеЗаполнено(Значение) Тогда
			Прервать;			
		КонецЕсли;
		
		мСписок.Добавить(Значение);
	КонецЦикла;	
	
	
	Запрос = Новый Запрос();
	Запрос.Текст = ЭтаФорма.ТекстЗапроса;
	Запрос.УстановитьПараметр("Список", мСписок);
	Выборка = Запрос.Выполнить().Выбрать();
	
	ВыборкаДанных = Новый Массив();
	
	Пока Выборка.Следующий() Цикл
		Элемент = Новый Структура(СтруктураДанных);
		Элемент.Ссылка = Выборка[0];
		ВыборкаДанных.Добавить(Элемент);
	КонецЦикла;
	
	Возврат ВыборкаДанных;
КонецФункции

Ещё в модуль формы была добавлена процедура "ИнициализироватьСтраницуОтборЗапросом", а в конец процедуры "ПриСозданииНаСервере" её вызов.

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)

	...


	ИнициализироватьСтраницуОтборЗапросом(ИмяТаблицыДанных, МетаИнфо);
КонецПроцедуры


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

Собственно, вот и вся модернизация.

Ну а теперь о том, как это работает:

Открываем модернизированную обработку, выбираем нужный узел обмена, находим интересующий нас объект, жмём правую кнопку мыши и, в появившемся контекстном меню, выбираем пункт "Зарегистрировать изменения при помощи отбора"

 

 

Если отбор по номерам документов в текущем году, то просто копируем нужные номера документов в таблицу "Список", если нет, то правим текст запроса.

 

 

Далее жмём кнопку "Выбрать запросом" и вуаля:

 

 

Если у вас нет времени, чтобы самому вносить изменения в типовую обработку "Регистрация изменений для обмена данными", можете скачать модернизированную мною обработку, взятую из типовой конфигурации УТ11 (11.5.13.74).

Обработка тестировалась на платформе 1С 8.3.22.2106.

#РегистрацияИзмененийЗапросом #РегистрацияИзмененийДляОбменаДанными #РегистрацияИзмененийДляОбменаДаннымиЗапросом

См. также

[ED3] Обмен для ERP 2.5, КА 2.5, УТ 11.5 БП 3.0, Розница, УНФ и других с EnterpriseData (универсальный формат обмена), правила обмена

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

25080 руб.

12.06.2017    135951    732    291    

393

SALE! 10%

Перенос данных из УПП 1.3 в ERP 2 / УТ 11 / КА 2. Переносятся документы, справочная информация и остатки

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

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) в продаже с 2015 года, постоянно работаем над их развитием | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

50722 45650 руб.

04.08.2015    160910    357    268    

349

SALE! 10%

Перенос данных из ERP 2 / КА 2 / УТ 11 в БП 3.0. Переносятся документы, начальные остатки и справочники

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | В продаже с 2019г. | Воспользовались более 176 предприятий! | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой, обращайтесь!

38500 34650 руб.

15.04.2019    69138    181    139    

111

SALE! 10%

Перенос данных из БП 3.0 в УТ 11 / КА 2 / ERP 2. Переносятся начальные остатки, документы и справочники

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

В продаже с 2014г. | Воспользовались более 122 предприятий! | Перенос данных из БП 3.0 в УТ 11 | из БП 3.0 в КА 2 | из БП 3.0 в ERP | Сэкономьте свое время - используйте готовое решение для перехода! | Постоянно работаем над развитием переноса данных | Обновляем на новые релизы 1С | Есть фильтр выгрузки по организациям | Переносятся начальные остатки на выбранную дату, документы за период времени и вся возможная справочная информация | Перенос сделан на технологии КД 2 (правила конвертации данных)

50722 45650 руб.

31.10.2014    232681    126    327    

298

Перенос данных из УПП 1.3 в БП 3.0. Переносятся документы (обороты за период), справочная информация и остатки

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.226.x) и БП 3.0 (3.0.151.x). Правила подходят для версии ПРОФ и КОРП.

28000 руб.

15.12.2021    20775    136    38    

95

Перенос данных из УТ 10.3 в УТ 11.5. Переносятся документы (обороты за период), справочная информация и остатки

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 1С:Управление торговлей 11 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.87.x) и УТ 11.5 (11.5.16.x).

28000 руб.

23.07.2020    47072    201    64    

162

SALE! 10%

Перенос данных из ERP 2 / КА 2 в ЗУП 3. Переносятся остатки, документы и справочники

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Воспользовались более 79 предприятий! | Предлагаем приобрести готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | В продаже с 2020г. | Оперативно обновляем правила до актуальных релизов 1С | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

48278 43450 руб.

03.12.2020    34598    83    58    

81

SALE! 10%

Перенос данных из БП 3.0 в УНФ 3.0 / УНФ 1.6. Переносятся остатки, документы и справочная информация

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

В продаже с 2018г. | Воспользовались более 41 предприятия! | Правила конвертации (КД 2) для переноса данных из БП 3 в УНФ | Переносятся все виды документов, начальные остатки и вся возможная справочная информация | Есть фильтр по организациям | Оперативно обновляем на новые релизы | Оказываем техподдержку | В комплект файлов входит инструкция, авторская версия обработки "Универсальный обмен...", актуальные правила переноса данных и архив старых версий переноса | Учет в БП 3 должен быть корректным, некорректные данные не переносятся | Можно бесплатно проверить на вашем сервере до покупки!

50722 руб.

10.07.2018    68005    41    123    

46
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Ili4hKing 21.08.23 09:15 Сейчас в теме
Статья хорошая, но почему просто не воспользовались конструкцией
Объект = Ссылка.ПолучитьОбъект();
Объект.ОбменДанными.Получатели.Добавить(Узел);
Объект.Записать();

Такой вариант был бы проще, и его можно выполнить из большинства запросников
2. triviumfan 93 21.08.23 10:46 Сейчас в теме
(1) Или так)
ПланыОбмена.ЗарегистрироватьИзменения(Получатели, Данные)
Ili4hKing; +1 Ответить
4. Eugen-S 390 21.08.23 12:14 Сейчас в теме
(2) Вот эту штуку я пробовал, но почему-то типовая обработка "Регистрация изменений для обмена данными" не показала, что добавленные таким образом объекты находятся в очереди обмена.
Возможно раньше такой подход работал, но на УТ11 (11.5.13.74) - этот способ не "взлетел" :(
3. Eugen-S 390 21.08.23 11:38 Сейчас в теме
(1) Зачем лишний раз перезаписывать объект, если можно обойтись без этого.
К тому же, а если объект в исходной базе в закрытом периоде, для этого действа нужно будет специально открывать период.
5. svbel85 57 22.08.23 17:47 Сейчас в теме
Инструментами разработчика часто делаю так, выбираю консолью запроса - результат передаю в подбор и обработку объектов - и там регистрирую на узле
Оставьте свое сообщение