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

03.04.14

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

Описана возможность использования обработки «Консоль запросов 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
находится список запросов с простыми примерами использования запросов в режиме «консоль кода».

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

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

См. также

INFOSTART TECH EVENT 2023, 11-13 октября, Санкт-Петербург

Инструментарий разработчика Мобильная разработка DevOps и автоматизация разработки Администрирование СУБД Мероприятия Россия Платные (руб)

XIII конференция по управлению и технологиям автоматизации учета на платформе 1С:Предприятие, которая пройдет в Санкт-Петербурге и соберет 1500 участников из разных регионов России и мира.

5100 руб.

09.12.2022    30068    5    0    

424

Онлайн-интенсив "DevOps для 1С". с 4 сентября по 17 октября 2023 г.

Инструментарий разработчика DevOps и автоматизация разработки DevOps для 1С Платные (руб)

Данный онлайн-курс (интенсив) предусматривает изучение процессов, инструментов и методик DevOps, их применение при разработке на платформе 1С. 

20.06.2023    9730    0    Infostart    2    

120

SALE! %

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

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

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

12000 10000 руб.

02.09.2020    93244    476    380    

531

PowerTools

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

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

3600 руб.

14.01.2013    170090    1050    0    

791

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

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

Программист - это человек, непрерывно принимающий решения. Написание кода не является процессом принятия решения - это всего лишь трансляция ваших желаний. Если вас периодически тяготит написание сотен строк кода ради решения задач, то прошу обратить внимание. Данный продукт позволит существенно сократить время на рутинные операции при разработке. За счет библиотечной реализации сокращается объём кода, а его читаемость повышается. К библиотеке прилагается документация API и шаблоны кода для наиболее популярных методов.

4200 руб.

16.04.2021    12445    3    9    

9

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

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

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

5000 руб.

07.02.2018    96425    234    97    

285

Менеджер конфигураций 1С

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

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

1439 руб.

21.02.2023    5218    2    33    

14

Программное формирование существующих печатных форм

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

Получение списка печатных форм, формирование выбранной печатной формы и сохранение ее в файл.

1 стартмани

17.12.2021    14067    39    RocKeR_13    5    

46
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. yuraos 988 03.04.14 14:22 Сейчас в теме
Ну вот ... еще одна консоль кода.
Уважаемых гуру прошу сильно не ругаться.
;)))
2. yuraos 988 18.01.23 17:11 Сейчас в теме
!33333!.txt
Прикрепленные файлы:
!33333!.txt
!33333!.txt
Оставьте свое сообщение