Подсистема "COMExchange": консоль запросов в режиме «Консоль кода».

Публикация № 269792

Разработка - Инструментарий разработчика - Консоль запросов

консоль кода консоль запросов

8
Описана возможность использования обработки «Консоль запросов 1С+ADO» в качестве «консоли кода». При этом имеется возможность помещения результатов вычислений в «табло формул». Кроме результатов вычислений в это «табло» можно также вывести время выполнения и описание обработанных ошибок времени исполнения.

В обработке «Консоль запросов 1С+ADO» подсистемы «COMExchange» изначально была заложена поддержка «событий».
Событие в данном случае - это  произвольный исполняемый код на встроенном языке,
выполняемый в определенные моменты функционирования обработки.


В настоящий момент в консоли поддерживаются события двух видов:

  1. События выполнения запросов: «ПередЗапросом», «ПослеЗапроса»;
  2. События обработки выборки запроса: «ПередВыборкой», «Выборка», «ПослеВыборки»;

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

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

Поддержка событий (выполнения произвольного кода) уже превращает обработку в своего рода «консоль кода».
Ведь нам ничто не запрещает использовать событие «ПередЗапросом» не по прямому назначению, а просто для выполнения любого пользовательского кода.
Установка же флага СтандартнаяОбработка = Ложь в обработчике события позволяет не выполнять обработку текста запроса (и даже не задавать его).
В этом случае запуск самого запроса на выполнение фактически не происходит, выполняются только обработчики событий выполнения запроса.


Чтобы сделать использование обработки «Консоль запросов 1С+ADO»  в качестве «консоли кода» более удобным

в версии обработки 8.1.1.3 сделаны следующие нововведения:

1.  Шаблоны заполнения запросов:

  1. Шаблон «Запрос 'Консоль кода'»;
  2. Шаблон «Запрос 'Консоль кода' (примеры)».

    Первый шаблон создает пустую «консоль кода» в текущей строке дерева списка запросов.
    Второй шаблон создает «консоль кода» с закомментаренными примерами использования.

    Выбор шаблона заполнения производится из контекстного меню,
    выводимого кликом правой клавишей мыши по «функциональной» кнопке «f(x)»;

    Шаблоны заполнения запросов

2.  Встроенные функции модуля объекта обработки:

  1. Функции для работы с «табло формул» - позволяют инициализировать «табло формул», вставлять и получать из «табло» результаты вычислений;
  2. Функции для получения объектов отчетов и обработок – позволяет использовать в исполняемом коде отчеты и обработки (как встроенные, так и внешние).

    Встроенные функции для работы с


Общее описание запроса в режиме «консоль кода»:

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

Для вставки пользовательского кода предназначена область текста обработчика между комментариями
‘’// *** ИСПОЛНЯЕМЫЙ КОД ***’’ и ‘’// ^^^ ИСПОЛНЯЕМЫЙ КОД ^^^’’.

Предусмотрено определенное удобство для редактирования кода: при нажатии на «функциональную» кнопку «f(x)»
выводится контекстное меню для вставки в текст часто используемых фрагментов кода (см. рисунок выше).

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

Выполнение пользовательского кода в

При совместном использовании обработки с подсистемой "ViewValues" (которая входит в комплект поставки подсистемы «COMExchange»)
доступны расширенные возможности просмотра значений в «табло формул» при двойном клике мышью по ячейке с результатом.

Просмотр результатов в табло формул средствами подсистемы

Для этого в версиях подсистемы "ViewValues" 8.1.1.5 /8.2.1.5 значительно расширен список типов объектов, доступных для «просмотра».
Таким образом, теперь возможен «просмотр» табличных частей объектов, наборов записей регистров, строк табличных, записей регистров,
ключей записей регистров и многое другое (смотрите описание подсистемы).


Дополнительные возможности запроса в режиме «консоль кода»:

  1. В дереве списка запросов можно создать любое количество «консолей кода».
    При этом при выполнении кода текущей «консоли кода» можно запускать на выполнение другие «консоли кода» по их имени в списке.
    После «выполнения» другой «консоли кода» можно использовать значения из ее «табло формул» в текущих вычислениях или
    помещать в это «табло» текущие результаты.
    Единственное ограничение – запрещен рекурсивный запуск запросов на выполнение (непосредственно или через цепочку вызовов).
  2. В тексте кода с помощью встроенной функции getExecTime() можно засекать время выполнения фрагмента кода в миллисекундах
    и выводить его в «табло» (вместе с результатом);
  3. В тексте кода можно обрабатывать ошибки времени исполнения в блоке Попытка – Исключение и
    выводить в «табло» информацию об ошибке (вместо результата);
  4. Возможно выполнение «обычного» запроса из дерева списка и использование его результатов в текущих вычислениях;
  5. Естественно список «консолей кода» может быть сохранен во внешнем файле (*.selx) для его повторного использования;


Материалы в комплекте поставки:

В архиве комплекта поставки подсистемы «COMExchange» в файле
..\COMExchange-8x.rar\\COMExchange-8x\Sampls\ПримерыКонсольКода.selx
находится список запросов с простыми примерами использования запросов в режиме «консоль кода».

Также примеры использования «консоли кода» можно посмотреть в запросе,
заполненном по шаблону «Запрос 'Консоль кода' (примеры)».

8

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо
1. yuraos 954 03.04.14 14:22 Сейчас в теме
Ну вот ... еще одна консоль кода.
Уважаемых гуру прошу сильно не ругаться.
;)))
Оставьте свое сообщение

См. также

[8.3] Анализ планов запросов (Управляемая консоль отчетов) 131

Статья Программист Нет файла v8 1cv8.cf Бесплатно (free) Консоль запросов

Новый инструмент! Позволяет удобно работать с планами запросов, анализ планов в файловой базе.

19.11.2018    13886    Evg-Lylyk    6       

Консоль запросов для УФ с возможностью передачи готовой ТЗ в качестве параметра 15

Статья Программист Нет файла v8 v8::УФ Россия Windows Бесплатно (free) Консоль запросов

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

11.07.2016    12430    vadim1011985    7       

Консоль запросов. Очередная гайка. 18

Статья Программист Нет файла v8 1cv8.cf Windows Бесплатно (free) Консоль запросов

Небольшое дополнение к консоли запросов. Позволяет создавать функцию вместе с текстом запроса.

23.07.2014    6382    mdmdvd    3       

Подсистема "COMExchange", консоль запросов, сервис обработки выборки запроса: корректируем регистры или «Берём банк, кассу, экспроприируем экспроприаторов». 7

Статья Системный администратор Программист Нет файла v8 1cv8.cf Россия Windows Бесплатно (free) Консоль запросов

На примере шуточного примера продемонстрированы не шуточные возможности консоли запросов в составе подсистемы "COMExchange" для работы с регистрами, подчинёнными регистратору («обнуление» регистров, ввод начальных итогов (сведений), корректировка итогов).

31.03.2013    20158    yuraos    7       

Подсистема "COMExchange", "Консоль запросов 1C + ADO" - сервис обработки выборки запроса: грузим курс «бакса» ЦБРФ из файла *.dbf или *.xlsx. 7

Статья Системный администратор Программист Нет файла v8 КА1 УТ10 УПП1 Россия Windows Бесплатно (free) Консоль запросов

На примере загрузки курса валюты продемонстрированы возможности консоли запросов в составе подсистемы "COMExchange" для обработки данных из внешних файлов и их синхронизации с данными информационной базы 1С.

10.03.2013    30608    yuraos    3       

Полезные вкусняшки: Консоль запросов от GROOVY 84

Инструменты и обработки Системный администратор Программист Внешняя обработка (ert,epf) v8 1cv8.cf Россия Бесплатно (free) Консоль запросов

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

19.09.2007    25757    1591    GROOVY    17