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

21.08.23

Интеграция - Перенос данных 1C

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Регистрация изменений для обмена данными МД v1.0:
.epf 142,42Kb
19
19 Скачать (1 SM) Купить за 1 850 руб.

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

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

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

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

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

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

 

 

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

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

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

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

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

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

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

	...


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


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

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

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

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

 

 

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

 

 

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

 

 

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

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

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

См. также

SALE! 10%

Перенос данных 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. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    143335    821    297    

428

SALE! 10%

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

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

55778 50200 руб.

04.08.2015    168368    344    279    

380

SALE! 10%

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

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

35000 31500 руб.

23.07.2020    53428    236    73    

192

SALE! 10%

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

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

35000 31500 руб.

15.12.2021    24829    174    51    

132

SALE! 10%

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

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

53111 47800 руб.

03.12.2020    37249    99    66    

95

Перенос данных 1C Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ ФОМС, ЕФС Платные (руб)

Обработки для быстрого перехода с конфигураций «КАМИН:Расчет заработной платы 3.0», «КАМИН:Зарплата для бизнеса 4.0» и «КАМИН:Зарплата 5.0» на конфигурацию «Зарплата и управление персоналом» версии 3.1.

12000 руб.

25.09.2016    81568    324    253    

276

SALE! 10%

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

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    172021    307    258    

384

Зарплата Внешние источники данных Бюджетный учет Перенос данных 1C Системный администратор Программист Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактическим удержаниям, НДФЛ, вычетам, страховым взносам из базы Парус 8 учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

120000 руб.

19.08.2020    25695    25    1    

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

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