Как известно тот запрос, который разработчик создает в источнике данных, система компоновки данных не просто может, но и по факту меняет исходя из своего понимания, как нужно оптимально сформировать запрос. Часто при разработке отчетов в СКД возникает ситуация, когда не совсем понятно, почему отчет выводит не те данные, которые нужны, либо не выводит вовсе. Возникает потребность увидеть конечный запрос, который формирует СКД. Как это сделать рассмотрим в этой статье.
Создаем отчет «Взаиморасчеты с покупателями»
Создадим отчет, который будет выводить данные по регистру накопления «Взаиморасчеты с покупателями»:
Создадим структуру отчета и укажем выбранные поля:
Проверим результат:
Добавим отбор по контрагенту, также дадим пользователю возможность указать контрагента на форме отчета:
Проверим результат:
Теперь наша задача посмотреть, какой запрос выполняет СКД. Сделаем это двумя способами.
Вариант 1. Через управляемую консоль запросов, отчетов
Для того, чтобы посмотреть итоговый запрос через управляемую консоль запросов и отчетов нужно сохранить схему компоновки в файл:
Далее открываем управляемую консоль запросов, отчетов (далее консоль запросов и отчетов) и загружаем в нее схему компоновки данных нашего отчета. Для работы со схемой компоновки данных в консоли запросов и отчетов нам потребуется толстый клиент, так как запуск конструктора схемы компоновки данных возможен только в толстом клиенте:
Рисунок 7. Создаем схему компоновки данных в консоли запросов и отчетов
Таким образом наш отчет загружен в консоль запросов и отчетов:
Проверим результат:
Теперь нам нужно посмотреть итоговый запрос, который СКД использует при построении отчета. Это можно сделать, нажав на кнопку «Анализ исполняемых запросов результата».
Таким образом мы получили итоговый запрос, который использует СКД при формировании запроса. Также можно нажать на кнопку «Сравнить с исходным текстом» (Рис. 14) и в одном окне посмотреть исходный и итоговый запросы:
Вариант 2. При программном формировании отчета СКД
При разработке отчетов бывают ситуации, когда загрузить отчет в консоль запросов и отчетов не представляется возможным, либо это сделать очень трудоемко. Например, когда у отчета задано большое количество параметров. В таком случае можно воспользоваться вторым способом просмотра итогового отчета СКД - «При программном формировании».
Сформируем отчет программно. Для этого откроем конфигуратор, добавим отчет в дерево объектов метаданных и в модуле объекта отчета пропишем:
Далее укажем точку останова и запустим отладку. Итоговый запрос можно найти в выражении «МакетКомпоновки.НаборыДанных.НаборДанных1.Запрос».
Таким образом мы выполнили поставленную задачу - просмотрели итоговый запрос через консоль запросов и отчетов, а также при программном формировании отчета.
Исходные данные
Платформа «1С:Предприятие 8.3, учебная версия (8.3.24.1342)» (Windows).
Ссылки на материалы
Управляемая консоль запросов, отчетов: https://infostart.ru/1c/tools/835718/
Чем мы можем быть полезны
Если вы в поиске работы в сфере 1С, приходите к нам🙂
- Оклад до 200 000 ₽ к начислению — точную сумму предложим после собеседования;
- Фиксированный доход, не зависящий от загрузки и оплат клиентов;
- Бонус каждые полгода по итогам работы.
Подробнее на нашем сайте.
И подписывайтесь на наш телеграм канал🧑💻👩💻 Пишем технические статьи про разработку, публикуем новости из мира 1С и делимся опытом выполненных проектов.