Семерых одним ударом: ищем все ошибки в запросе за один раз!

05.03.25

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

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Консоль запроса с полной проверкой (УФ)
.epf 116,40Kb ver:1.0
2
2 Скачать (2 SM) Купить за 2 150 руб.

Коллеги, приветствую!

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

Суть проблемы в том, что при проверке корректности текста запроса мы получаем текст только самой первой ошибки, которая в запросе встречается. И пока мы её не исправим, все остальные ошибки мы получить не сможем.

Но что, если нам нужно проверить запрос и получить сразу список всех ошибок?

Решая данную задачу, я классифицировал ошибки на две группы:

- ошибки синтаксиса (где-то забыли поставить точку с запятой или скобочку)

- ошибки метаданных (обращаемся к реквизиту или таблице, которых не существует в базе)

Скажу честно, с синтаксическими ошибками запроса я ещё не разбирался, и там есть в каком направлении работать.

Но с ошибками метаданных я вроде бы вопрос решил.

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

Что я имею ввиду под исправлением на лету?

В данном случае рассматриваются ошибки вида «Поле не обнаружено» и «Таблица не обнаружена».

Приведём пример:

ВЫБРАТЬ
                Валюты.Код КАК Код,
                Валюты.Наименование КАК Наименование,
                Валюты.ОсновнаяВалюта КАК ОсновнаяВалюта,
                Валюты.НеизвестныйРеквизит1 КАК НеизвестныйРеквизит1,
                Валюты.НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2
ИЗ
                Справочник.Валюты КАК Валюты

Выполнив проверку этого запроса, мы получим следующую ошибку:

{(5, 9)}: Поле не найдено "Валюты.НеизвестныйРеквизит1"

Валюты.<<?>>НеизвестныйРеквизит1 КАК НеизвестныйРеквизит1,

Воспользуемся парсингом строк и извлечём поле, которое вызывает ошибку:  "Валюты.НеизвестныйРеквизит1"

Дальше мы делаем замену данной строки на ИСТИНА.

Получаем следующий текст запроса:

ВЫБРАТЬ
                Валюты.Код КАК Код,
                Валюты.Наименование КАК Наименование,
                Валюты.ОсновнаяВалюта КАК ОсновнаяВалюта,
                ИСТИНА КАК НеизвестныйРеквизит1,
                Валюты.НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2
ИЗ
                Справочник.Валюты КАК Валюты

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

{(6, 9)}: Поле не найдено "Валюты.НеизвестныйРеквизит2"
Валюты.<<?>>НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2

Данный метод помог нам получить сразу две ошибки из запроса.

Следующий пример:

ВЫБРАТЬ
                ДолжностиСотрудников.Ссылка КАК Ссылка,
                ДолжностиСотрудников.Код КАК Код,
                ДолжностиСотрудников.Наименование КАК Наименование
ПОМЕСТИТЬ ВремТабл
ИЗ
                Справочник.ДолжностиСотрудников КАК ДолжностиСотрудников
ГДЕ
                ДолжностиСотрудников.Код = &Код
;

////////////////////////////////////////////////////////////////////////////////

ВЫБРАТЬ
                Валюты.Код КАК Код,
                Валюты.Наименование КАК Наименование,
                Валюты.ОсновнаяВалюта КАК ОсновнаяВалюта,
                Валюты.НеизвестныйРеквизит1 КАК НеизвестныйРеквизит1,
                Валюты.НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2,
                ВремТабл.Ссылка КАК Ссылка
ИЗ
                Справочник.Валюты КАК Валюты,
                ВремТабл КАК ВремТабл

 

Проверка данного запроса выдаёт ошибку:

{(7, 2)}: Таблица не найдена "Справочник.ДолжностиСотрудников"
<<?>>Справочник.ДолжностиСотрудников КАК ДолжностиСотрудников

Что мы делаем: достаём строку с названием таблицы "Справочник.ДолжностиСотрудников"

Идём в 7 строку запроса и заменяем её, например, на «ВременнаяТаблица1».

ВЫБРАТЬ
                ДолжностиСотрудников.Ссылка КАК Ссылка,
                ДолжностиСотрудников.Код КАК Код,
                ДолжностиСотрудников.Наименование КАК Наименование
ПОМЕСТИТЬ ВремТабл
ИЗ
                ВременнаяТаблица1 КАК ДолжностиСотрудников
ГДЕ
                ДолжностиСотрудников.Код = &Код
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
                Валюты.Код КАК Код,
                Валюты.Наименование КАК Наименование,
                Валюты.ОсновнаяВалюта КАК ОсновнаяВалюта,
                Валюты.НеизвестныйРеквизит1 КАК НеизвестныйРеквизит1,
                Валюты.НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2,
                ВремТабл.Ссылка КАК Ссылка
ПОМЕСТИТЬ ВТ
ИЗ
                Справочник.Валюты КАК Валюты,
                ВремТабл КАК ВремТабл

Таким нехитрым способом мы смогли «пропустить» данную ошибку, и проверить запрос дальше.

В итоге использования данного алгоритма мы получим сразу список из трёх ошибок:

{(7, 2)}: Таблица не найдена "Справочник.ДолжностиСотрудников"
<<?>>Справочник.ДолжностиСотрудников КАК ДолжностиСотрудников

{(17, 9)}: Поле не найдено "Валюты.НеизвестныйРеквизит1"
Валюты.<<?>>НеизвестныйРеквизит1 КАК НеизвестныйРеквизит1,

{(18, 9)}: Поле не найдено "Валюты.НеизвестныйРеквизит2"
Валюты.<<?>>НеизвестныйРеквизит2 КАК НеизвестныйРеквизит2,

Из синтаксических ошибок я пока что реализовал только исправление «на лету» пропущенной точки с запятой между запросами в пакете.

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

В файлах выкладываю популярную консоль запросов на УФ, в которую встроена кнопка с моей проверкой. При желании, можно встроить в любую консоль за 5 минут.

 

 

Если есть желание, предлагайте варианты обхода других ошибок в запросе, будем дорабатывать алгоритм вместе)) Всем удачи!

Проверено на следующих конфигурациях и релизах:

  • 1С:ERP Управление предприятием 2, релизы 2.5.21.99

обработка проверка запросов консоль запросов

См. также

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

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

15500 руб.

02.09.2020    177573    986    403    

943

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

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

8400 руб.

20.08.2024    19077    127    70    

130

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

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

15000 руб.

10.11.2023    12791    53    33    

72

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

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

22200 руб.

06.10.2023    18751    49    19    

82

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

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

9360 руб.

17.05.2024    28899    100    48    

146

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

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

20000 руб.

07.10.2021    18611    7    32    

43

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

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1708    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. dehro 12 06.03.25 07:03 Сейчас в теме
А если временная таблица сформирована в другом запросе и передана через менеджер временных таблиц?
2. XilDen 573 06.03.25 07:16 Сейчас в теме
(1) А в чём вопрос? Ситуация, которую вы описали, не является ошибкой и проверка тоже не обнаруживает ошибки в таком запросе.
Можете попробовать открыть в конструкторе такой запрос, например, он откроется без ошибок:

 ВЫБРАТЬ
	ВТ.Ссылка КАК Ссылка,
	ВТ.Сотрудник.Код КАК Код,
	ВТ.Наименование КАК Наименование
ИЗ
	ВТ КАК ВТ
3. dehro 12 06.03.25 07:25 Сейчас в теме
(2) Так те ошибки, которые в статье, конструктор запроса выдаёт легко.
А то что по одной, а не скопом меня ни разу не напрягало.

Хуже, когда конструктор открывает, но при выполнении запрос "падает"))
5. XilDen 573 06.03.25 08:06 Сейчас в теме
(3) Статья не о том, что я нахожу какие-то ошибки, которые не обнаруживаются конструктором) Статья ровно о том, чтобы обнаруживать все ошибки, которые выдаёт конструктор, но "скопом") В некоторых ситуациях бывает полезно)
4. glek 120 06.03.25 07:48 Сейчас в теме
(2) В данном примере как раз и отвалится с ошибкой, если не написать выразить(вт.сотрудник как справочник.сотрудники).код, например :-)
6. XilDen 573 06.03.25 08:08 Сейчас в теме
(4) Возможно от версии платформы зависит) Но у меня данный запрос открывается в конструкторе без ошибок и выглядит так:
Прикрепленные файлы:
7. XilDen 573 06.03.25 08:11 Сейчас в теме
8. RustIG 1837 06.03.25 09:05 Сейчас в теме
сделайте таблицу со строками ошибок с номером строки, при активации строки с ошибкой, чтобы в запросе выделялась нужная строка.
также в этой таблице ставьте по умолчанию в колонку ЗаменяемоеЗначение = "Истина", но с возможностью прописать свое поле
Оставьте свое сообщение