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

05.10.14

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

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

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

Наименование Файл Версия Размер
МодификацияСхемыЗапроса.epf
.epf 10,23Kb
282
.epf 1.0.1 10,23Kb 282 Скачать
Граф типов схемы запроса
.rar 620,93Kb
98
.rar 620,93Kb 98 Скачать

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

 

О работе со схемой запроса можно почитать на сайте 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! 20%

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

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

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

13000 10400 руб.

02.09.2020    122231    673    389    

715

SALE! 25%

Infostart PrintWizard

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

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

18000 15300 руб.

06.10.2023    7312    22    6    

39

SALE! 20%

Infostart УДиФ: Управление данными и формами

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

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

10000 8000 руб.

10.11.2023    3560    11    1    

34

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    177767    1074    0    

849

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

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

5000 руб.

07.02.2018    99359    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

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

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    18122    6    8    

40

1С HTML Шаблоны / HTML Templates

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

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    28114    3    10    

15

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

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

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

2400 руб.

24.09.2019    23605    15    15    

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

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

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

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

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

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

з.ы. ссылку поправила.
10. boln 1040 05.10.14 20:20 Сейчас в теме
8. boln 1040 05.10.14 19:34 Сейчас в теме
Также исправьте ссылку на статью в Зазеркалье - сейчас она ведет на эту страницу.
11. It-developer 24 12.12.14 11:27 Сейчас в теме
еще одна прикольная вещь
12. MaxS 2827 26.03.15 10:30 Сейчас в теме
Очень полезная обработка! Хотелось бы ещё фичу:
1) По тексту запроса строится программный код для создания этого запроса.
2) Расширение п.п.1 - сравнение двух запросов и построение программного кода...
13. ekaruk 4897 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 4897 03.03.16 07:55 Сейчас в теме
(14) webester, Возможно, у конфигурации режим совместимости 8.2.
16. webester 26 03.03.16 12:45 Сейчас в теме
(15)Да действительно. Есть вопрос к вам, как к человеку который более менее смог разобрать эту модель. Как добавить вложенный запрос? Я понимаю, что надо добавлять источник, но на этом все. Дальше какой то темный лес. Со всеми остальными данными понятно указываем текстом регистр или документ\справочник и поля\псевдонимы к нему. Не могу понять, что надо делать тут. Обработка должна была помочь, но пока тупик. Может почитать где то можно про это?
17. fedor40 705 30.04.17 10:29 Сейчас в теме
НЕ работает.

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

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

НЕТ в дереве псевдонимов колонок и т.п.
Прикрепленные файлы:
18. Vladimir Litvinenko 2869 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 1053 19.04.21 10:09 Сейчас в теме
(20) Схема запросов поддерживает только существующие поля в источнике. Поле "*" будет воспринято как синтаксическая ошибка, т.к. не соответствует правилам именования.
21. slawa 26 18.04.21 16:27 Сейчас в теме
Как мне добавить например условие не помеченные на удаление?
Прикрепленные файлы:
22. kalyaka 1053 19.04.21 10:03 Сейчас в теме
(21) должно быть так: нужно добавить строку отбора с условием
НЕ ТЧ.СчетУчета.ПометкаУдаления
24. slawa 26 21.04.21 04:25 Сейчас в теме
Что написать в запросе я знаю :)
Как это действие сделать с помощью этой обработки (МодификацияСхемыЗапроса) ?
25. kalyaka 1053 21.04.21 07:37 Сейчас в теме
(24) я как раз имел в виду обработку, а не текст запроса. Дело в том, что условия в схеме можно записать только текстом, как в тексте запроса. Т.е. аналогия с условиями для СКД здесь не работает.
26. Дмитрий74Чел 234 27.07.21 13:37 Сейчас в теме
Выбирать объекты для модификации не очень удобно. Особенно, когда требуется несколько таблиц внести в запрос.
Идея для доработки:
1) вводим исходный запрос
2) вводим модифицированный запрос (создали руками в конструкторе)
3) обработка выдает готовый код для модификации исходного запроса в новый
27. ekaruk 4897 27.07.21 13:42 Сейчас в теме
(26) Эта обработка просто помощник по работе со схемой запроса.
Понять, как обратиться к конкретной части запроса.
Полностью автоматически создать код для преобразования одного запроса в другой достаточно проблематично. Слишком много вариантов.
28. kalyaka 1053 27.07.21 14:59 Сейчас в теме
(26) Для решения такой задачи в общем виде прямой способ модификации нецелесообразно сложный. Дело в том, что при модификации схемы могут возникать побочные эффекты. Таким образом алгоритм модификации помимо своей прямой задачи должен будет также решать задачу устранения побочных эффектов.

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

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

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