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

03.03.26

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

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

Файлы

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

Наименование Скачано Купить файл
Консоль запроса с полной проверкой (УФ)
.epf 117,46Kb ver:1.1
14 3 000 руб. Купить
Консоль запроса с полной проверкой (УФ)
.epf 116,40Kb ver:1.0
7 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

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

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

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

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

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

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

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

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

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

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

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

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

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

ВЫБРАТЬ
                Валюты.Код КАК Код,
                Валюты.Наименование КАК Наименование,
                Валюты.ОсновнаяВалюта КАК ОсновнаяВалюта,
                Валюты.НеизвестныйРеквизит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 минут.

 

 

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

 

ОБНОВЛЕНО 07.03.2025:

Выложил версию 1.1.

  • Реализован вывод списка ошибок в таблицу с возможностью перемещения к строке с ошибкой при двойном клике.
  • Добавлена обработка пропуска ошибки с пропущенной запятой, например:
ВЫБРАТЬ
    ВТ.Ссылка КАК Ссылка,
    ВТ.Сотрудник.Код КАК Код
    ВТ.Наименование КАК Наименование
ИЗ
    ВТ КАК ВТ

 

  • Добавлена обработка ошибки с лишней запятой, например:
 ВЫБРАТЬ
    ВТ.Ссылка КАК Ссылка,
    ВТ.Сотрудник.Код КАК Код,
    ВТ.Наименование КАК Наименование,
ИЗ
    ВТ КАК ВТ

Актуальный внешний вид обработки:

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

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

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

Вступайте в нашу телеграмм-группу Инфостарт

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

См. также

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

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

24900 руб.

20.08.2024    69952    365    170    

316

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

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

16500 руб.

02.09.2020    260859    1351    421    

1170

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм. Обновление версии от 21.04.26

22570 руб.

06.10.2023    38687    107    46    

122

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

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданным 1С, справке синтакс-помощника и проверки синтаксиса.

15250 руб.

25.08.2025    56996    114    32    

126

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

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

17000 руб.

10.11.2023    25595    93    46    

102

Мастера заполнения Поиск данных Инструментарий разработчика Подбор и обработка объектов 1С 8.3 1С 8.5 Платные (руб)

Infostart MagicInput улучшает подбор в полях ввода 1С: ищет по любой части названия и по нескольким ключевым фрагментам, распознаёт ввод в другой раскладке и показывает иконки/статусы объектов прямо в списке. Поддерживает вставку навигационной ссылки/представления документа для автоподбора; для разработчиков доступны поиск по GUID и полному имени предопределённого. Работает в управляемых формах и подключается в большинстве конфигураций 1С 8.3/8.5.

6000 руб.

25.02.2026    4022    13    1    

18

Инструментарий разработчика Разработка Администрирование веб-серверов Системный администратор Программист Бизнес-аналитик Руководитель проекта 1С 8.3 Платные (руб)

В крупных внедрениях 1С типовая почти всегда дополнена расширениями, а конфигуратор показывает их раздельно. «Поиск ссылок на объект» в ERP — минуты ожидания, и даже после него неясно: типовое поведение, дополнение из расширения или переопределённый обработчик. Analyzer 1C — веб-инструмент, который парсит выгрузку (основную плюс все расширения) и собирает единый граф знаний в ArangoDB. Любой межсущностный запрос — за доли секунды. Внутри: — Сквозные пометки «Доб.» / «Заимств.» / переопределения во всём UI — Импакт-анализ через подписки, регламентные задания и переопределения — Анализ запросов BSL: кто читает и пишет объект — модули, формы, СКД — Роли: матрица «роль × объект × право», RLS, программные РольДоступна, PRIV — Конструктор профилей, граф функций, обработчики обновления, XDTO, функциональные опции — Мгновенный поиск по конфигурации Разворачивается за минуту через Docker, без интернета. Любая 1С:Предприятие 8.3+.

12200 руб.

17.04.2026    6596    28    33    

43

Инструментарий разработчика Программист 1С:Предприятие 8 Платные (руб)

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

9500 руб.

17.05.2024    53373    185    63    

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

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

Хуже, когда конструктор открывает, но при выполнении запрос "падает"))
5. XilDen 794 06.03.25 08:06 Сейчас в теме
(3) Статья не о том, что я нахожу какие-то ошибки, которые не обнаруживаются конструктором) Статья ровно о том, чтобы обнаруживать все ошибки, которые выдаёт конструктор, но "скопом") В некоторых ситуациях бывает полезно)
Oksana_Makr; mefalcon; +2 Ответить
4. glek 119 06.03.25 07:48 Сейчас в теме
(2) В данном примере как раз и отвалится с ошибкой, если не написать выразить(вт.сотрудник как справочник.сотрудники).код, например :-)
6. XilDen 794 06.03.25 08:08 Сейчас в теме
(4) Возможно от версии платформы зависит) Но у меня данный запрос открывается в конструкторе без ошибок и выглядит так:
Прикрепленные файлы:
7. XilDen 794 06.03.25 08:11 Сейчас в теме
(4) Платформа 8.3.24.1738
8. RustIG 1955 06.03.25 09:05 Сейчас в теме
сделайте таблицу со строками ошибок с номером строки, при активации строки с ошибкой, чтобы в запросе выделялась нужная строка.
также в этой таблице ставьте по умолчанию в колонку ЗаменяемоеЗначение = "Истина", но с возможностью прописать свое поле
11. XilDen 794 07.03.25 13:48 Сейчас в теме
(8) Первую часть вашего предложения реализовал в версии 1.1) Про заменяемое значение - это было бы актуально, если бы мы делились с пользователем исправленной версией запроса. В текущей версии мы пользователю этого не показываем, хотя, вариант развития интересный, подумаю на эту тему)
12. RustIG 1955 07.03.25 14:01 Сейчас в теме
(11) бывает что чисто машинально пропустил букву - в торопях написал "Ревизит", забыл "к" - да, конструктор поругается , что такого поля нет, но у вас есть таблица с ошибками - ставим в заменяемое значение "Реквизит" и движемся далее - не надо здесь "Истина", здесь надо именно дописать букву "к"
+ другие сценарии, но это пока не важно обсуждать
9. acsent 1207 06.03.25 22:56 Сейчас в теме
А если запятую пропустить - сможет другие ошибки найти?
10. XilDen 794 07.03.25 13:07 Сейчас в теме
(9) Сегодня выложил версию 1.1, в ней это реализовано
Для отправки сообщения требуется регистрация/авторизация