Как посмотреть итоговый запрос в отчете СКД

15.05.24

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

Часто при разработке отчетов в СКД возникает ситуация, когда не совсем понятно, почему отчет выводит не те данные, которые нужны, либо не выводит вовсе. Возникает потребность увидеть конечный запрос, который формирует СКД. Как это сделать, рассмотрим в этой статье.

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

Часто при разработке отчетов в СКД возникает ситуация, когда не совсем понятно, почему отчет выводит не те данные, которые нужны, либо не выводит вовсе. Возникает потребность увидеть конечный запрос, который формирует СКД. Как это сделать, рассмотрим в этой статье.

 

Создаем отчет «Взаиморасчеты с покупателями»

Создадим отчет, который будет выводить данные по регистру накопления «Взаиморасчеты с покупателями»:

 

Рисунок 1. Набор данных «Запрос» в отчете
 

Создадим структуру отчета и укажем выбранные поля:

 

Рисунок 2. Структура отчета и выбранные поля в отчете
 

Проверим результат:

 

Рисунок 3. Результат работы отчета
 

Добавим отбор по контрагенту, также дадим пользователю возможность указать контрагента на форме отчета:

 

Рисунок 4. Отбор по контрагенту в отчете
 

Проверим результат:

 

Рисунок 5. Результат работы отчета с отбором
 

Теперь наша задача посмотреть, какой запрос выполняет СКД. Сделаем это двумя способами.

 

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

Для того, чтобы посмотреть итоговый запрос через управляемую консоль запросов и отчетов, нужно сохранить схему компоновки в файл:

 

Рисунок 6. Выгрузка схемы компоновки отчета в файл
 

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

 

Рисунок 7. Создаем схему компоновки данных в консоли запросов и отчетов
 

 

Рисунок 8. Открываем конструктор в консоли запросов и отчетов в схеме компоновки данных
 

 

Рисунок 9. Загружаем схему компоновки данных в консоль запросов и отчетов
 

Таким образом наш отчет загружен в консоль запросов и отчетов:

 

Рисунок 10. Отчет в консоли запросов и отчетов
 

 

Рисунок 11. Отбор по контрагенту в отчете СКД в консоли запросов и отчетов
 

Проверим результат:

 

12.png

Рисунок 12. Проверяем работу отчета в консоли запросов и отчетов
 

Теперь нам нужно посмотреть итоговый запрос, который СКД использует при построении отчета. Это можно сделать, нажав на кнопку «Анализ исполняемых запросов результата».

 

13.png

Рисунок 13. Кнопка «Анализ исполняемых запросов результата» в консоли запросов и отчетов
 

 

14.1.png

Рисунок 14. Итоговый запрос, который использует СКД при формировании отчета
 

Таким образом мы получили итоговый запрос, который использует СКД при формировании запроса. Также можно нажать на кнопку «Сравнить с исходным текстом» (Рис. 14) и в одном окне посмотреть исходный и итоговый запросы:

 

14.png

Рисунок 15. Исходный и итоговый запрос в консоли запросов и отчетов
 

 

Вариант 2. При программном формировании отчета СКД

При разработке отчетов бывают ситуации, когда загрузить отчет в консоль запросов и отчетов не представляется возможным, либо это сделать очень трудоемко. Например, когда у отчета задано большое количество параметров. В таком случае можно воспользоваться вторым способом просмотра итогового отчета СКД - «При программном формировании».

Сформируем отчет программно. Для этого откроем конфигуратор, добавим отчет в дерево объектов метаданных и в модуле объекта отчета пропишем:

 

15.png

Рисунок 16. Программное формировать отчета
 

Далее укажем точку останова и запустим отладку. Итоговый запрос можно найти в выражении «МакетКомпоновки.НаборыДанных.НаборДанных1.Запрос».

 

16.png

Рисунок 17. Просмотр итогового запроса при программном формировании отчета
 

Таким образом мы выполнили поставленную задачу - просмотрели итоговый запрос через консоль запросов и отчетов, а также при программном формировании отчета.

 

Исходные данные

Платформа «1С:Предприятие 8.3, учебная версия (8.3.24.1342)» (Windows).

 

Ссылки на материалы

Управляемая консоль запросов, отчетов: //infostart.ru/1c/tools/835718/

См. также

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

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

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

10000 руб.

02.09.2020    129743    700    390    

752

СКД на JavaScript в 1С

СКД WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

11.12.2023    8788    20    John_d    25    

124

Модель СКД

Инструментарий разработчика СКД Платформа 1С v8.3 Система компоновки данных Абонемент ($m)

DSL для работы с СКД.

1 стартмани

15.11.2023    6329    15    kalyaka    5    

89

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

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

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

11.10.2023    17006    skovpin_sa    14    

102

Разрыв страницы в СКД. Легко!

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

Когда отчет надо разделить по страницам, это всегда проблема для разработчика. Поскольку в СКД нет стандартных вариантов, как это сделать. Нашел (на свой взгляд) самое простое и оптимальное решение.

01.09.2023    5039    KVIKS    15    

80

MS SQL Server: изучаем планы запросов

Запросы HighLoad оптимизация Запросы Бесплатно (free)

Многие знают, что для ускорения работы запроса нужно «изучить план». При этом сам план обычно обескураживает: куча разноцветных иконок и стрелочек; ничего не понятно, но очень интересно! Аналитик производительности Александр Денисов на конференции Infostart Event 2021 Moscow Premiere рассказал, как выполняется план запроса и что нужно сделать, чтобы с его помощью находить проблемы производительности.

20.06.2023    18323    Филин    37    

114

Вывод элементов иерархии верхнего уровня на СКД

СКД Платформа 1С v8.3 Абонемент ($m)

Как получить родителя первого уровня иерархического справочника с помощью СКД.

1 стартмани

06.06.2023    7025    echo77    6    

80

Все консоли запросов для 1С

Запросы Инструментарий разработчика Бесплатно (free)

Список всех популярных обработок.

17.03.2023    39983    kuzyara    87    

184
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Светлый ум 406 16.05.24 07:00 Сейчас в теме
+1
молодцом, вечно приспичивает эта инструкция, а под рукой нет
3. implecs_team 120 16.05.24 15:56 Сейчас в теме
(1) Рады, что смогли помочь!
2. cheshirshik 64 16.05.24 14:06 Сейчас в теме
Как у вас все сложно. А использовать инструменты разработчика не пробовали? Может сначала мы делаем там запрос. Отлаживаем, а в финале переносим ХМЛ схему в отчет? Не?

К чему я это все? У 1С есть замечательная тема. Кэширование. Вот делаешь ты запрос делаешь, а результат нет. В чем проблема? А проблема в кэше. Пока его не обновишь запрос и отчет работать по-новому не будут. ИР помогают в этом плане. Не приходится каждый раз при изменении чего либо чистить кэш.
4. asadroman 16.05.24 16:04 Сейчас в теме
Все через костыли... все через костыли...
корум; +1 Ответить
Оставьте свое сообщение