Сверка справочников в разных базах одним запросом

10.03.19

Разработка - Запросы

Публикация размещена исключительно в образовательных целях и подходит только для платформы версии 8.3.9.2033.
Использует недокументированные средства доступа к базе данных 1С. Прямое обращение к СУБД нарушает лицензионное соглашение,
может изменить поведение платформы, привести к разрушению базы данных, скомпрометировать данные,
а также привести к отказу в официальной поддержке Фирмы 1С.
Микро-конфигурация 1С, демонстрирующая на примере сверки справочников возможность обращения в одном запросе SQL к объектам разных информационных баз. Демонстрируется выполнение и обработка результата пакетного запроса SQL для одновременного получения сверочной информации в различных разрезах. Конфигурация содержит общий модуль с полным набором функций и процедур необходимых для полноценного использования прямого обращения к базам данных на MS SQL. Проверено на платформе 1С:Предприятие 8.3 (8.3.9.2033), обычные формы.

Скачать файлы

Наименование Файл Версия Размер
Сверка справочников в разных базах одним запросом
.cf 49,32Kb
7
.cf 49,32Kb 7 Скачать

Так уж вышло, что за время работы в сфере ИТ - вот уже более 15 лет - я трудился в основном в крупных компаниях федерального масштаба, где информационная система состоит из большого количества различных БД как типовых так и существенно измененных (порой до неузнаваемости) конфигураций 1С. Как правило, базы в подобных системах имеют внушительный  размер и связаны между собой непростой сетью всевозможных обменов при высокой степени нагрузки и большом количестве пользователей. В описанных условиях, и это мое глубокое убеждение, невозможно построить качественную работоспособную систему без прямой работы с данными в том или ином виде.  Переубедить меня в этом не удастся никому - не пытайтесь. Я никого не агитирую за масштабное использование SQL при построении алгоритмов Вашей информационной системы, использование методов прямого доступа к данным - исключительно вынужденная мера, когда все типовые способы 1С уже себя исчерпали.

В рамках публикации предлагаю демонстрационную конфигурацию 1С, которая содержит объекты:

 - общий модуль "РаботаСSQL" с необходимым набором функций для работы с запросами SQL:

 - Служебные справочники "БазыДанных" и "ТаблицыХраненияДанных" для хранения параметров подключения и имен сверяемых объектов.

 - Обработка "СверкаСправочников" для демонстрации метода сверки. Представленной обработкой производится только сверка по основным служебным реквизитам "Ссылка, Код, Наименование" в различных вариациях.

Ограничения:

 - Для работы с демо-конфигурацией необходимы административные права и знание параметров доступа к серверу SQL, на котором расположены сверяемые базы.

 - Сверяемые базы должны находиться на одном сервере SQL. Создание  и использование  связанных серверов в представленном наборе функций не реализовано.

 - В сверяемых справочниках должны обязательно присутствовать реквизиты "Код" и "Наименование".

 - Конфигурация не получает структуру хранения данных сверяемых объектов. Внутренние имена таблиц необходимо получить другими средствами, к примеру набором ИР:

Подсистема "Инструменты разработчика" v4.79, автору низкий поклон - настоящий МАСТЕР.

Инструкция по работе с Конфигурацией.

Возможны 2 варианта работы: подключение к произвольному серверу и работа со справочниками, в которых зарегистрированы параметры подключения и имена сверяемых объектов.

1. Работа со справочниками:

 - Зарегистрируйте параметры подключения к сверяемым базам в справочнике "БазыДанных":

 

- Зарегистрируйте соответствие имен сверяемых объектов в справочнике "ТаблицыХраненияДанных":

 

- Обновите списки выбора баз и справочников командой "Обновить списки выбора":

 

- Заполните поля сверяемых объектов и выполните команду "Выполнить сверку":

 

- Результат сверки отобразится на соответствующих вкладках панели результата:

 

2. Вариант подключения к произвольному серверу.

- Переключите режим работы на "Подключение к произвольным базам":

 

- При необходимости подключения к серверу, отличному от предыдущего, выполните команду "Обновить списки выбора".

- На 1 вкладке объекта "DataLinks" выберите поставщика OLE DB для SQL Server:

- На 2 вкладке укажите параметры подключения:

 После подключения списки баз и справочников автоматически заполнятся внутренними именами СУБД.

- Заполните поля сверяемых объектов и выполните команду "Выполнить сверку" подобно предыдущему варианту сверки:

- Результат:

Выполняемый запрос отображается на вкладке "Запрос сверки":

 

Заключение.

Подобным образом можно производить быструю сверку документов одновременно в нескольких базах, к примеру, для поиска документов с расхождением по сумме. Или просто получить какие либо итоговые данные из регистров нескольких баз для сводного отчета. 

Всем удачи!

SQL сверка справочников документов прямые запросы

См. также

SALE! 20%

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

Инструментарий разработчика Роли и права Запросы СКД Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 8000 руб.

02.09.2020    122372    673    389    

716

Для чего используют конструкцию запроса "ГДЕ ЛОЖЬ" в СКД на примере конфигурации 1С:ERP

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных 1С:ERP Управление предприятием 2 Бесплатно (free)

В типовых конфигурациях разработчики компании 1С иногда используют в отчетах, построенных на СКД, такую конструкцию, как "ГДЕ ЛОЖЬ". Такая конструкция говорит о том, что данные в запросе не будут получены совсем. Для чего же нужен тогда запрос?

13.02.2024    5756    KawaNoNeko    23    

23

Набор-объект для СКД по тексту или запросу

Запросы СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Есть список полей в виде текста, или запрос - закидываем в набор СКД.

1 стартмани

31.01.2024    2006    2    Yashazz    0    

29

Запрос 1С copilot

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

Пишем на человеческом языке, что нам надо, и получаем текст запроса на языке 1С. Используются большие языковые модели (LLM GPT) от OpenAI или Яндекс на выбор.

5 стартмани

15.01.2024    6300    31    mkalimulin    25    

50

PrintWizard: поддержка представлений ЗУП в конструкторе

Инструментарий разработчика Запросы Платформа 1С v8.3 Бесплатно (free)

Одной из интересных задач, стоящих в процессе разработки, была поддержка механизма представлений в ЗУП. Но не просто возможность исполнения запросов с ними. Основная проблема была в том, чтобы с ними было удобно работать, а именно: создавать, модифицировать и отлаживать. Кратко о том, что в итоге получилось...

14.12.2023    1749    vandalsvq    7    

29

Объектная модель запроса "Схема запроса" 2

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

Далеко уже не новый тип данных "Схема запроса". Статья о том, как использовать его "попроще". Примеры создания текста запроса с нуля и изменение имеющегося запроса.

06.12.2023    5398    user1923546    26    

43

Начните уже использовать хранилище запросов

HighLoad оптимизация Запросы

Очень немногие из тех, кто занимается поддержкой MS SQL, работают с хранилищем запросов. А ведь хранилище запросов – это очень удобный, мощный и, главное, бесплатный инструмент, позволяющий быстро найти и локализовать проблему производительности и потребления ресурсов запросами. В статье расскажем о том, как использовать хранилище запросов в MS SQL и какие плюсы и минусы у него есть.

11.10.2023    16198    skovpin_sa    14    

98
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Cерый 25 13.03.19 19:27 Сейчас в теме
Прямая работа с SQL ограничивает доступ к данным, заранее исключая локальные и веб-серверные базы 1С;
базы 1С могут получать данные других баз по COM-соединению, это типовой способ 1С, собственно, он исчерпал себя в применимости к операционным системам, не относящимся к Windows не более,
этот вариант использует пароли уровня пользователя 1С, Ваш вариант использует пароли уровня администратора - деление, возможно, довольно условное, часто сложно-преодолимое препятствие для внедрений;
из модуля РаботаСSQL оригинальное решение - функция СсылкаИзSQL, работа функций ЗначениеВСтрокуВнутр/ЗначениеИзСтрокиВнутр не ограничена атомарными значениями,
полученная таблица на стороне COM-соединения может быть преобразована в таблицу значений:

Запрос = ОбъектCOM.NewObject("Запрос");
...
Результат = Запрос.Выполнить().Выгрузить();
Таблица = ЗначениеИзСтрокиВнутр(ОбъектCOM.ЗначениеВСтрокуВнутр(Результат))
Оставьте свое сообщение