РИБ на v 8: Фильтрация данных по узлам распределенной информационной базы.

09.08.07

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

Часто, при работе в распределенной информационной базе, существует необходимость в выборочной миграции данных по узлам, когда поведение по умолчанию (т.е. любое изменение элемента данных, произведенное в любом из узлов, стремится распространиться по всем остальным узлам) не подходит.
Часто, при работе в распределенной информационной базе, существует необходимость в выборочной миграции данных по узлам, когда поведение по умолчанию (т.е. любое изменение элемента данных, произведенное в любом из узлов, стремится распространиться по всем остальным узлам) не подходит.
В общем случае, существует два подхода к решению этой задачи:
1. Отключение для всех объектов с выборочной миграцией авто регистрации и проверка при записи необходимости регистрации изменения объекта (для последующей отправки в узел).
2. Фильтрация данных непосредственно при записи сообщения обмена.
Здесь я хотел бы рассмотреть второй способ, который, на мой взгляд, является более интересным. Фильтрация данных обычно происходит по признаку «принадлежности» этих данных к организации, подразделению, складу и т.д. Таким образом, нужно при записи сообщения обмена, определить (по какому-либо из реквизитов записываемых в текущий момент данных) необходимость отправки этих данных в текущий узел «получатель».
Приведу пример. Существует распределенная информационная база, имеющая один корневой узел и некоторое количество периферийных узлов, используется типовая конфигурация «Бухгалтерия предприятия». Задача заключается в реализации схемы обмена, при которой за каждым из периферийных узлов «закреплена» одна или несколько организаций, по которым в этом узле ведется учет. Соответственно, необходимо, что бы в периферийные узлы попадали данные только по определенной организации (нескольким организациям), а в центральном узле «собирались» все данные.
Для решения этой задачи, в плане обмена добавим табличную часть "ОрганизацииУзла", имеющую одну колонку "Организация", тип "СправочникСсылка.Организации". Далее, в модуле плана обмена, в процедуре ПриОтправкеДанныхПодчиненному(), добавим следующий текст:
Процедура
ПриОтправкеДанныхПодчиненному
(
ЭлементДанных
,
ОтправкаЭлемента
) Если
ТипЗнч
(
ЭлементДанных
)=
Тип
("УдалениеОбъекта") Тогда Возврат
;
  	
КонецЕсли
;
  	ОбъектМетаданных
=
ЭлементДанных
.Метаданные()
;
  	
Если Метаданные.
Документы
.
Содержит
(
ОбъектМетаданных
) Тогда Если
ЕстьРеквизитДокумента
("Организация",
ОбъектМетаданных
) Тогда Если
глТекущийУзел
.
ОрганизацииУзла
.
Найти
(
ЭлементДанных
.
Организация
,"Организация")=
Неопределено 
Тогда
ОтправкаЭлемента
=
ОтправкаЭлементаДанных
.
Игнорировать;
    			
КонецЕсли
;
   		
КонецЕсли
;
  	
ИначеЕсли Метаданные.
РегистрыНакопления
.
Содержит
(
ОбъектМетаданных
) ИЛИ Метаданные.
РегистрыБухгалтерии
.
Содержит
(
ОбъектМетаданных
) Тогда
Регистратор
=
ЭлементДанных
.
Отбор
.
Регистратор
.
Значение;
   		
Если
ЕстьРеквизитДокумента
("Организация",
Регистратор
.Метаданные()) Тогда Если
глТекущийУзел
.
ОрганизацииУзла
.
Найти
(
Регистратор
.
Организация
,"Организация")=
Неопределено 
Тогда
ОтправкаЭлемента
=
ОтправкаЭлементаДанных
.
Игнорировать;
    			
КонецЕсли
;
   		
КонецЕсли
;
  	
ИначеЕсли Метаданные.
РегистрыСведений
.
Содержит
(
ОбъектМетаданных
) Тогда Если
ЭлементДанных
.
Отбор
.
Найти
("Регистратор")<>
Неопределено 
Тогда
Регистратор
=
ЭлементДанных
.
Отбор
.
Регистратор
.
Значение;
    			
Если
ЕстьРеквизитДокумента
("Организация",
Регистратор
.Метаданные()) Тогда Если
глТекущийУзел
.
ОрганизацииУзла
.
Найти
(
Регистратор
.
Организация
,"Организация")=
Неопределено 
Тогда
ОтправкаЭлемента
=
ОтправкаЭлементаДанных
.
Игнорировать;
     				
КонецЕсли
;
    			
КонецЕсли
;
   		
КонецЕсли
;
  	
КонецЕсли
;
КонецПроцедуры
Что бы при записи сообщения обмена, можно было определить, для какого узла в данный момент записывается сообщение, необходимо добавить глобальную переменную или параметр сеанса, в данном случае используется переменная глТекущийУзел. В эту переменную предварительно должен быть установлен текущий узел «получатель», так как внутри процедуры ПриОтправкеДанныхПодчиненному() не предусмотрено получение текущего узла. Таким образом, осталось в режиме «Предприятие» установить организации для подчиненных узлов. Следует заметить, что иногда имеет смысл вместо ОтправкаЭлементаДанных.Игнорировать использовать ОтправкаЭлементаДанных.Удалить, что бы удалить в подчиненных узлах ошибочно попавшие туда данные. Например, если из-за ошибки оператора, в документе, изначально неверно был установлен реквизит, по которому происходит фильтрация. Аналогично можно реализовать выборочную миграцию по любому другому реквизиту или даже набору реквизитов.

См. также

SALE! 20%

Перенос данных из УПП 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 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

45650 36520 руб.

04.08.2015    159693    363    267    

345

SALE! 15%

[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 22572 руб.

12.06.2017    134940    723    291    

388

SALE! 20%

Перенос данных из 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 | Можно проверить на вашем сервере перед покупкой, обращайтесь!

34650 27720 руб.

15.04.2019    68422    178    138    

111

SALE! 20%

Перенос данных из 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С | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

43450 34760 руб.

03.12.2020    34170    80    58    

78

SALE! 10%

Перенос данных из УТ 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 25200 руб.

23.07.2020    46301    196    64    

158

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    231417    124    327    

296

Перенос данных из Парус 10 в ЗГУ ред.3

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

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

60000 руб.

05.10.2022    9208    9    8    

10

SALE! 10%

Перенос данных из УПП 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.223.x) и БП 3.0 (3.0.149.x). Правила подходят для версии ПРОФ и КОРП.

28000 25200 руб.

15.12.2021    20252    132    38    

90
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. coder1cv8 3468 15.08.07 15:11 Сейчас в теме
Эта... Комментарии приветствуются, что ли.
2. Zombie11 03.09.07 11:02 Сейчас в теме
3. il1973 21.05.08 19:32 Сейчас в теме
4. СветикК 31.05.09 09:30 Сейчас в теме
Эх, а если нужно выгрузить данные, которые сделали движения только по налоговому учету, в этой процедуре ПриОтправкеДанныхПодчиненному() проверку вставить ? (((
5. СветикК 31.05.09 09:41 Сейчас в теме
еще и при полном варианте выгррузке... (
6. StSanek 03.06.09 11:02 Сейчас в теме
нормуль, внедрил на Управление Торговлей на первый взляд все внорме. Благодарен.... Спасибо...........
7. Lilya 02.07.09 12:12 Сейчас в теме
8. skylive 05.08.09 14:20 Сейчас в теме
Подскажите, как эту вещь внедрить в УТ ред. 10.3:
А именно:
1. Исправить ошибку: Процедура или функция с указанным именем не определена (ЕстьРеквизитДокумента)
2. Как "добавить глобальную переменную или параметр сеанса, в данном случае используется переменная глТекущийУзел. В эту переменную предварительно должен быть установлен текущий узел «получатель»"
9. coder1cv8 3468 05.08.09 14:38 Сейчас в теме
(8) В УТ 10.3 (насколько я помню) реализовали уже механизм фильтрации через правила обмена, советую пользоваться им...
А по поводу вопросов:
1. Посмотреть в каком модуле теперь распологается эта функция (или, быть может у нее изменилось имя?) и вызывать "через точку" с именем модуля.
2. В конфигураторе добавляем параметр, делаем обработку "обертку" нашего обмена и в ней перед формированием сообщения этот параметр устанавливаем.
10. Sova123 34 18.08.09 15:35 Сейчас в теме
2. В конфигураторе добавляем параметр, делаем обработку "обертку" нашего обмена и в ней перед формированием сообщения этот параметр устанавливаем. - вот это не понятно, что за "обертку", написала вот так вот на сколько это правильно???
Процедура ПриОтправкеДанныхПодчиненному(ЭлементДанных, ОтправкаЭлемента)


Текущий_Узел_Получатель = ЭтотОбъект.Ссылка;

Если ТипЗнч(ЭлементДанных)=мТипУдалениеДанных Тогда
Возврат;
КонецЕсли;
ОбъектМетаданных=ЭлементДанных.Метаданные();

Организация = ЭлементДанных;

Если ТипЗнч(Организация) = Тип("СправочникОбъект.Организации") Тогда

Если Организации.Найти(Организация.Ссылка, "Организация") = Неопределено Тогда

ОтправкаЭлемента = ОтправкаЭлементаДанных.Удалить;

КонецЕсли;

ИначеЕсли ТипЗнч(Организация) = Тип("СправочникОбъект.ДоговорыКонтрагентов") Тогда

Если Организации.Найти(Организация.Организация.Ссылка, "Организация") = Неопределено Тогда

ОтправкаЭлемента = ОтправкаЭлементаДанных.Удалить;

КонецЕсли;


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

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

КонецЕсли;
КонецЕсли;
КонецЕсли;
КонецЕсли;
КонецПроцедуры
11. coder1cv8 3468 19.08.09 11:03 Сейчас в теме
(10) Что значит "насколько правильно"? ) Разве это хоть как-то работает?... )
12. coder1cv8 3468 19.08.09 11:11 Сейчас в теме
+(11) В аську пишите 366-836-253 попробую "разжевать"...
20. heavymetal 86 09.06.17 12:58 Сейчас в теме
(11) по логике должно работать, это же модуль объекта того самого узла
13. kvp 19.10.11 10:45 Сейчас в теме
Спасибо!!! Статья оказалась очень кстати. Внедряю в УТ 10.3.
14. piterantares 239 04.09.12 13:34 Сейчас в теме
Внедрил! Год назад. Спасибо!
Есть минусы, хотя это, похоже не минусы идеи, а минусы реализации 1С )))
Частность.
Накопления по дисконтным картам не мигрируются по магазинам разных организаций
15. harutyunb 09.02.14 12:22 Сейчас в теме
Можно это же самое для новой версии подсистемы библиотек?
16. CSiER 35 17.04.16 16:36 Сейчас в теме
(15) harutyunb, из БСП старой весрии:
// Позволяет определить есть ли среди реквизитов шапки документа реквизит с переданным именем.
Функция ЕстьРеквизитДокумента(ИмяРеквизита, МетаданныеДокумента) Экспорт
	Если МетаданныеДокумента.Реквизиты.Найти(ИмяРеквизита) = Неопределено Тогда
		Возврат Ложь;
	Иначе
		Возврат Истина;
	КонецЕсли; 
КонецФункции // ЕстьРеквизитДокумента()
heavymetal; +1 Ответить
17. Akuji 22 29.07.16 11:59 Сейчас в теме
что то не очень по моему вариант 2 "Фильтрация данных непосредственно при записи сообщения обмена"...

я правильно понимаю что документы при выгрузке игнорируются по отбору (тут все ОК)
НО
они (документы) остаются в базе как помеченные для выгрузки и за год их накопится огромная куча - которая будет при каждой выгрузке проверятся?

Я вот еще только начал его внядрять натестил за день кучку документов. Внес в конфигурацию изменения и запустил обновление конфигурации БД.
Уже час наверное висит:
Реструктуризация РегистрСведений.ОбъектыДоступаДокументов таблица регистрации изменений ...
18. kulidge 6 26.08.16 09:36 Сейчас в теме
(17) Akuji, При правильной фильтрации ничего копится не должно.
19. kulidge 6 26.08.16 09:39 Сейчас в теме
а про накопление по дисконтным картам...можно чтобы во все периферийные базы ходил только регистр, а не документ-регистратор, как вариант - ведь нужны только суммы накоплений
21. masik777 17.01.20 14:05 Сейчас в теме
StSanek 03.06.09 11:02
Вы писали, что " внедрил на Управление Торговлей" Если не сложно для Вас, поделитесь, пожалуйста на maxnal@list.ru
Или тут. Очень выручите, кто так и не смог разобраться. Вкючаяя меня))
Писали, что на УТ 10 это уже реализовано. Не нашел где и как делать.((
22. CaSH_2004 372 27.03.24 20:04 Сейчас в теме
Поправьте кто нибудь в статье код, он весь поломанный - невозможно прочесть, какая то обфускация ((
Оставьте свое сообщение