Сравнение запросов

27.10.24

Разработка - Инструментарий разработчика

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

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Сравнение запросов, вер. 2.2, обычные формы
.epf 28,54Kb ver:2.2
0 1 850 руб. Купить
Сравнение запросов, вер. 2.3, обычные формы
.epf 28,49Kb ver:2.3
2 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

"Однажды переписал огромный запрос на новый запрос с новыми таблицами и связями, при этом сохранив итоговый результат. Сдачу работ проводил через представленную в публикации обработку "Сравнение запросов". Заказчик работу принял. В ходе сдачи работ выявили особенность механизма запросов - запросы округляют не так как функции платформы - но это другая история.

Затем неоднократно использовал обработку "Сравнение запросов" в других подобных задачах совместно со стандартной типовой консолью запросов (самой простой без наворотов). В консоли создавал и отлаживал запрос, в обработке "Сравнение запросов" сравнивал исходный запрос с новым (из консоли)."

В итоге пришло понимание, что при внедрении новых механизмов приходится переделывать существующие запросы: к примеру, доработать исходный запрос, добавив новое соединение и условие. Получится ли на выходе тот же прежний результат - под вопросом. Для сравнения результатов исходного и нового запроса была разработана данная обработка.

Обработка тестировалась на платформе 1С:Предприятие 8.3 (8.3.13.1644), на конфигурации Управление торговлей, редакция 10.3 (10.3.47.3).

Обработка универсально подойдет для всех конфигураций на обычных формах.

* * *

Обязательные условия:

1) сравниваются только таблицы значений, а не деревья значений - поэтому выражения "Итогов" следует убрать из запросов;

2) ВНУТРЕННЕЕ соединение таблиц (результатов запроса) происходит по полям именованным "для связки", а сравнение таблиц происходит по полям именованным "для сравнения". 

3) стоит следить за параметрами и текстами запросов - иначе при запуске сравнения (выполнении запросов) выйдет ошибка СУБД.

Для демонстрации обработки сравниваются простые запросы - Срез первых и Срез последних по ценам номенклатуры. Для выделения расхождений созданы кнопки "Выделить расхождения" и "Отбор по расхождениям" - см. рис. ниже.

Параметры запросов по факту могут быть разными, потому что запросы могут отличаться. А вот поля для связки у двух результирующих таблиц и поля для сравнения у двух результирующих таблиц (после выполнения запросов) должны быть одинаковыми - см. рис. ниже.

Имеется сохранение и открытие запросов - сохраняются тексты запросов, параметры запросов, поля связывания и сравнения. Работает только в ручном режиме (то есть не в автоматическом) - то есть для сохранения надо нажать кнопку "Сохранить" (Ctrl+S), для открытия (восстановления) нажать кнопку "Открыть файл" (см. рис. ниже).

Также можно использовать сохранение и восстановление запросов с помощью кнопок с зеленой стрелкой.

Если при сравнении запросов расхождений нет, то выходит сообщение "Расхождений не найдено". Если расхождения найдены, то выходит сообщение о тех полях, по которым найдены расхождения.

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

Имеется раздел сравнения временных таблиц - выбираете временные таблицы, которые необходимо сравнить => далее указываете для них поля связывания и поля сравнения => далее выполняете запросы ВТ (временных таблиц).

Временные таблицы определяются (инициализируются) по кнопке "Настроить запросы и врем. таблицы" с учетом заданных Параметров (кнопка "Параметры").

Не забудьте изменить поля связывания и поля сравнения после выбора временных таблиц для сравнения (см. рис. ниже).

Временные таблицы могут иметь разные названия. Названия можно сопоставить в таблице временных таблиц из выпадающего списка выбора (см. рис. ниже).

Версия 2.2 - соединение таблиц ВНУТРЕННЕЕ.

Версия 2.3 - соединение таблиц ПОЛНОЕ.

Доработал обработку для ПОЛНОГО соединения (версия 2.3) - то есть в результате получим все записи первой ("левой") таблицы и все записи второй ("правой") таблицы. Такое необходимо, если вы ищите обширную разницу между двумя таблицами (результатами запросов). На основе результирующих расхождений можно увидеть, какие записи не попадают в первый или во второй запрос. 

Для понимания порядка работы с обработкой дополнительно пронумерованы пошагово все кнопки - (см. рис. ниже).

Разработанный алгоритм сравнения двух таблиц значений также применяется при сравнении остатков по регистрам накопления между двумя базами (после свертки между рабочей базой и базой архивной копией, или между торговлей и бухгалтерией) - но это уже другая история...

Всем добра!

Проверено на следующих конфигурациях и релизах:

  • Управление торговлей, редакция 10.3, релизы 10.3.47.3

Вступайте в нашу телеграмм-группу Инфостарт

сравнение запросы

См. также

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

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

15500 руб.

02.09.2020    202377    1116    410    

1021

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    35562    206    104    

195

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    23955    62    26    

92

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

16000 руб.

10.11.2023    16445    69    39    

88

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

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    34644    123    53    

165

SALE! 30%

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

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 12600 руб.

22.11.2024    1710    1    0    

8

Инструментарий разработчика Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

6000 руб.

07.02.2018    107144    249    100    

313

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    2860    6    0    

11