Дерево объектной модели схемы запроса (декомпиляция текста запроса).

05.10.14

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

Удобный просмотр схемы запроса.
Формирование команд программной модификации запроса.

Скачать файл

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

Наименование По подписке [?] Купить один файл
МодификацияСхемыЗапроса.epf
.epf 10,23Kb ver:1.0.1
293
293 Скачать (1 SM) Купить за 1 850 руб.
Граф типов схемы запроса
.rar 620,93Kb
102
102 Скачать (1 SM) Купить за 1 850 руб.

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

 

О работе со схемой запроса можно почитать на сайте 1С Управляемый конструктор запроса и объектная модель схемы запроса

Отдельная моя статья о преимуществах модификации запроса через схему запроса  "Объектная модель запроса "Схема запроса" - теория и примеры использования"

Также на инфостарте есть Справочная схема "Объектная модель запроса"

 Порядок работы с обработкой:

1. Берем исходный текст запроса (копируем из конфигурации или пользуемся конструктором запроса)

2. Генерируем дерево запроса.

3. Находим в дереве нужные нам элементы и определяем пути к ним.

4. Двойным кликом по элементам дерева переносим нужные свойства в окно комманд.

5. Редактируем команды модификации запроса.

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

7. Проверенный набор команд переносим в конфигурацию.

Пример работы:

Исходный запрос:

ВЫБРАТЬ РАЗРЕШЕННЫЕ
	Контрагенты.Наименование КАК Наименование,
	Контрагенты.НаименованиеПолное КАК НаименованиеПолное,
	Контрагенты.ЮрФизЛицо КАК ЮрФизЛицо,
	Контрагенты.Партнер.Наименование КАК ПартнерНаименование
ИЗ
	Справочник.Контрагенты КАК Контрагенты
ГДЕ
	Контрагенты.ПометкаУдаления
	И Контрагенты.ЮридическоеФизическоеЛицо = &ЮридическоеФизическоеЛицо

Набор команд модификации:

// Изменяем псевдонимы полей
СхемаЗапроса.ПакетЗапросов[0].Колонки[0].Псевдоним = "НаименованиеНашейОрганизации";
СхемаЗапроса.ПакетЗапросов[0].Колонки[1].Псевдоним = "НаименованиеПартнера";
//Добавляем поле в запрос 
СхемаЗапроса.ПакетЗапросов[0].Операторы[0].ВыбираемыеПоля.Добавить("Контрагенты.Партнер.ОсновнойМенеджер");
//Добавляем условие отбора 
СхемаЗапроса.ПакетЗапросов[0].Операторы[0].Отбор.Добавить("Контрагенты.Наименование = &НаименованиеКонтрагента")

Итоговый текст запроса:

ВЫБРАТЬ РАЗРЕШЕННЫЕ
	Контрагенты.Наименование КАК НаименованиеНашейОрганизации,
	Контрагенты.НаименованиеПолное КАК НаименованиеПартнера,
	Контрагенты.ЮрФизЛицо КАК ЮрФизЛицо,
	Контрагенты.Партнер.Наименование КАК ПартнерНаименование,
	Контрагенты.Партнер.ОсновнойМенеджер
ИЗ
	Справочник.Контрагенты КАК Контрагенты
ГДЕ
	Контрагенты.ПометкаУдаления
	И Контрагенты.ЮридическоеФизическоеЛицо = &ЮридическоеФизическоеЛицо
	И Контрагенты.Наименование = &НаименованиеКонтрагента

UPD. Замечания по итогам обсуждений в комментариях:

1. Объектная модель запроса доступна с 8.3.5. Соответственно, на более ранних версиях работать не будет.

2. При модификации чужого запроса необходимо учитывать, что исходный запрос может измениться. В этом случае могут измениться пути к элементам и команды изменения работать перестанут. Эти моменты необходимо отслеживать при обновлении. Возможно, добавить проверки, что это именно нужный элемент и выдать сообщение, если по указанному пути элемент изменился.

В приложении сама обработка и граф типов схемы запроса.

В архиве схема в jpg, черно-белый вариант в .pdf для печати на А4, а также описание в dot-формате. Можно рассмотреть подробнее и изменить отображение на более удобное, например, через Graphviz.

схема запроса модификация запроса объектная схема запроса дерево запроса декомпиляция текста запроса

См. также

SALE! 15%

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

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

10000 руб.

02.09.2020    159307    872    399    

861

SALE! 15%

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

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

8400 7140 руб.

20.08.2024    7732    55    22    

66

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

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

9360 руб.

17.05.2024    23400    68    45    

117

SALE! 15%

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

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

10000 8500 руб.

10.11.2023    10400    36    20    

61

SALE! 15%

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

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

22200 19980 руб.

06.10.2023    15377    35    7    

70

SALE! 35%

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

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

4800 3120 руб.

14.01.2013    187956    1138    0    

912

SALE! 15%

Инструментарий разработчика Программист 8.3.14 1С:Конвертация данных Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

15000 12750 руб.

07.10.2021    17295    6    32    

42

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

Менеджер конфигураций 1С — альтернативный стартер информационных баз 1С:Предприятие.

1800 руб.

21.02.2023    7688    8    35    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 7229 05.10.14 08:29 Сейчас в теме
Привязка по индексам в коллекциях довольно опасна. Автору так не кажется?
Что будет, если поставщик вставит поле в выбранные поля или запрос в пакет? Факт этого сразу заметить будет в некоторых случаях очень непросто, т.к. искажение логики запроса может быть весьма не сразу понятным.
Дмитрий74Чел; dmpas; zqzq; Патриот; BigB; Yashazz; +6 Ответить
2. ekaruk 4975 05.10.14 08:42 Сейчас в теме
(1) tormozit, Согласна, есть такая проблема.
С большой вероятность ошибка всё-таки отловится, так как изменятся пути к элементам.
Например, например, станет недоступно в съехавшем пакете поле "Контрагенты.Партнер.ОсновнойМенеджер".
Либо следующий работающий с запросом код ругнется на изменение полей а результатах запроса.
Хотя, конечно, может проблема и проскочить незамеченной, нарушив при этом логику работы.
Пока не вижу вариантов решения.
Модель новая. Возможно, с наработкой практики какие-то варианты найдутся.

UPD. Как вариант, можно дописывать проверки, этот ли это реквизит.
Например, "Если имя элемента = <Имя>, то изменить на <ИмяНовое>, иначе выдать сообщение".
Аналогично на количество элементов в коллекции и другие свойства.
Если индексы сместятся, то проверка не пройдет и выдастся сообщение пользователю.
3. tormozit 7229 05.10.14 09:00 Сейчас в теме
(2) Для некоторых узлов дополнительную идентификацию можно проводить по самому содержимому, но в общем опасность универсально не устранима. Об этой опасности надо предупредить потенциальных пользователей методики.
4. ekaruk 4975 05.10.14 09:08 Сейчас в теме
(3) tormozit, Думаю, изначально объектная модель задумывалась для разработки новых запросов в зависимости от условий.
В этом случае разработчик сразу видит, что делает.
Подумаю еще на тему отслеживания изменений при модификации чужих запросов.
5. Yashazz 4790 05.10.14 10:44 Сейчас в теме
1. Вы бы это лучше в какой из вариантов классической/доработанной "КонсолиЗапросов" встроили, цены б ей не было. А то предложенный вариант, мягко говоря, хорош для понимания (которое у спеца и так есть), но не особо удобен для эксплуатации.

2. (1), (3) Целиком присоединяюсь, неудачно сделано. Надо понадёжнее, сами же на эти грабли встанете (проверено личным опытом).

3. Укажите, пожалуйста, что это легко фурычит и вообще актуально только для 8.3.5, а раньше все эти чудеса можно было лишь эмулировать тяжким трудом.
6. ekaruk 4975 05.10.14 11:29 Сейчас в теме
(5) Yashazz, спасибо за мнение, добавила примечания в статью.

Встраивать куда-либо пока смысла особого не вижу.
Основное применение это просмотр объектной схемы запроса и её модификация. Т.е. предполагается, что разработчик понимает, что хочет получить в итоге от запроса и необходимо лишь выяснить, как выполнить нужное изменение запроса программно.
Консоль запросов обычно у каждого своя, к которой человек привык.

Применения объектной модели именно для создания запросов с нуля смысла тоже не вижу.
Вернее, она и так применяется.
Стандартным конструкторов запросов.
Делать свой конструктор запросов смысла нет.
7. boln 1041 05.10.14 19:24 Сейчас в теме
Смелая идея, плюс.
Только, Евгения, имейте в виду, что Схема запроса на сегодня весьма капризна, а разработчик весьма упрям и концептуальные косяки свои признает только под изрядным давлением. Вот, почитайте мои терки с ним, если есть доступ к форуму:
https://partners.v8.1c.ru/forum/topic/1260107
9. ekaruk 4975 05.10.14 19:47 Сейчас в теме
(7) boln, Николай, спасибо.
Идея появилась еще после Вашего вебинара в УЦ3 по новым возможностям работы с запросами.
Наконец добралась до реализации :)
Доступ есть, почитала.
Я прекрасно понимаю, что эта модель еще будет меняться в новых релизах. Но, думаю, что общая концепция останется той же. Сама идея работы в объектной модели очень удобна, логична и давно применяется в других языках. Просто в 1С еще опыт использования не наработан. Пока просто разбираюсь для себя.

з.ы. ссылку поправила.
10. boln 1041 05.10.14 20:20 Сейчас в теме
8. boln 1041 05.10.14 19:34 Сейчас в теме
Также исправьте ссылку на статью в Зазеркалье - сейчас она ведет на эту страницу.
11. It-developer 26 12.12.14 11:27 Сейчас в теме
еще одна прикольная вещь
12. MaxS 2944 26.03.15 10:30 Сейчас в теме
Очень полезная обработка! Хотелось бы ещё фичу:
1) По тексту запроса строится программный код для создания этого запроса.
2) Расширение п.п.1 - сравнение двух запросов и построение программного кода...
13. ekaruk 4975 06.04.15 10:20 Сейчас в теме
(12) MaxS, По пункту 1 была такая мысль.
На момент статьи еще были некоторые проблемы со схемой запроса.
Не получилось сделать стабильно работающий алгоритм преобразования.
На 8.3.7 попробую реализовать.

По пункту 2, на мой взгляд нереально.
Одинаковые по смыслу и результату запросы могут строиться совершенно по-разному.
Их нельзя однозначно сопоставить и выделить отличия.
Наиболее адекватное сравнение - сравнение текста запроса.
Сравнивать объекты менее информативно.
14. webester 26 03.03.16 05:44 Сейчас в теме
При открытии обработки получаю
{Форма.Форма.Форма(49,81)} Переменная не определена(ЭтотОбъект)

Там находится Описание оповещения и вроде как на первый взгляд именно так оно и должно работать и раньше эта обработка у меня открывалась. Платформа 8.3.7.18.45 Не подскажете куда смотреть?
15. ekaruk 4975 03.03.16 07:55 Сейчас в теме
(14) webester, Возможно, у конфигурации режим совместимости 8.2.
16. webester 26 03.03.16 12:45 Сейчас в теме
(15)Да действительно. Есть вопрос к вам, как к человеку который более менее смог разобрать эту модель. Как добавить вложенный запрос? Я понимаю, что надо добавлять источник, но на этом все. Дальше какой то темный лес. Со всеми остальными данными понятно указываем текстом регистр или документ\справочник и поля\псевдонимы к нему. Не могу понять, что надо делать тут. Обработка должна была помочь, но пока тупик. Может почитать где то можно про это?
17. fedor40 706 30.04.17 10:29 Сейчас в теме
НЕ работает.

У меня 8.3.10 и описанные вами шаги в ней не возможны:

3. Находим в дереве нужные нам элементы и определяем пути к ним.
4. Двойным кликом по элементам дерева переносим нужные свойства в окно комманд.

НЕТ в дереве псевдонимов колонок и т.п.
Прикрепленные файлы:
18. Vladimir Litvinenko 2896 12.05.17 23:33 Сейчас в теме
Действительно помогает на практике. Особенно для модификации запросов динамических списков типовых конфигураций. Также помогает для модификации собираемых по частям запросов в типовых конфигурациях, когда менять текст запроса через СтрЗаменить рискованно или сложно, но пользуясь схемой запроса можно перебрать запросы пакета, определить нужные запросы на основе значения поля ТаблицаДляПомещения, после чего добавить в них новые поля или условия. Благодаря удобному визуальному представлению схемы, даже модификация вложенных запросов становится понятной и простой задачей. Спасибо за разработку.
Yan_Malyakov; BigMih; kalyaka; +3 Ответить
19. AllexSoft 05.02.19 23:54 Сейчас в теме
Отлично! В мои инструменты эта обработка точно попадет.. Для изменения конфигураций просто незаменима, особенно с учетом что 1С сделала везде вызовы модулей локализации, в которых можно программно изменять форму при создании на сервере..
20. varziev 06.07.19 16:09 Сейчас в теме
Как описать конструкцию
Выбрать *
в схеме запроса, а точнее в операторе пакета запроса, что бы не перечислять все поля из источника?
23. kalyaka 1105 19.04.21 10:09 Сейчас в теме
(20) Схема запросов поддерживает только существующие поля в источнике. Поле "*" будет воспринято как синтаксическая ошибка, т.к. не соответствует правилам именования.
21. slawa 26 18.04.21 16:27 Сейчас в теме
Как мне добавить например условие не помеченные на удаление?
Прикрепленные файлы:
22. kalyaka 1105 19.04.21 10:03 Сейчас в теме
(21) должно быть так: нужно добавить строку отбора с условием
НЕ ТЧ.СчетУчета.ПометкаУдаления
24. slawa 26 21.04.21 04:25 Сейчас в теме
Что написать в запросе я знаю :)
Как это действие сделать с помощью этой обработки (МодификацияСхемыЗапроса) ?
25. kalyaka 1105 21.04.21 07:37 Сейчас в теме
(24) я как раз имел в виду обработку, а не текст запроса. Дело в том, что условия в схеме можно записать только текстом, как в тексте запроса. Т.е. аналогия с условиями для СКД здесь не работает.
26. Дмитрий74Чел 239 27.07.21 13:37 Сейчас в теме
Выбирать объекты для модификации не очень удобно. Особенно, когда требуется несколько таблиц внести в запрос.
Идея для доработки:
1) вводим исходный запрос
2) вводим модифицированный запрос (создали руками в конструкторе)
3) обработка выдает готовый код для модификации исходного запроса в новый
27. ekaruk 4975 27.07.21 13:42 Сейчас в теме
(26) Эта обработка просто помощник по работе со схемой запроса.
Понять, как обратиться к конкретной части запроса.
Полностью автоматически создать код для преобразования одного запроса в другой достаточно проблематично. Слишком много вариантов.
28. kalyaka 1105 27.07.21 14:59 Сейчас в теме
(26) Для решения такой задачи в общем виде прямой способ модификации нецелесообразно сложный. Дело в том, что при модификации схемы могут возникать побочные эффекты. Таким образом алгоритм модификации помимо своей прямой задачи должен будет также решать задачу устранения побочных эффектов.

Образно это можно представить как перестройка многоэтажного дома, где каждый этаж - это запрос в пакете, а все стены (поля запроса) - несущие. Тогда при модификации на 1-ом этаже, если ничего не предпринять, весь дом разрушится :)

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

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