Поиск неоптимальных запросов SQL при помощи DMV

05.03.26

Разработка - Рефакторинг и качество кода

Сервер SQL хранит у себя данные по текущему состоянию и выполнению запросов. Например, какой запрос сколько раз выполнялся и сколько времени было потрачено. В топ таких запросов часто будут попадать тяжелые запросы и неоптимальные - которые и нужно будет найти и оптимизировать.

Файлы

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

Наименование Скачано Купить файл
Поиск неоптимальных запросов SQL при помощи DMV
.epf 16,74Kb
10 2 500 руб. Купить

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

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

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

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

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

Для обычных и управляемых форм.

На самом деле все просто... кратко про DMV

Обращаемся к служебным таблицам обычным SQL запросом и получаем, что там есть, включая текст запроса и план выполнения.

Сложности могут возникнуть только при отсутствии прав на эти таблицы.

Остаётся только найти в конфигураторе соответствующий запрос и исправить.

Функции по переводу SQL запроса в 1С взял у Андрея Бочкарева, спасибо!

 

Пример отчета:

 

Данные цифры говорят о том, что запрос номер 1 выполнялся 4873 раза и сервер SQL затратил в общей сумме 110 минут. 

Частая история к этой картине: В справочник добавили реквизит и ищут по этому реквизиту. При каждом поиске идет полное сканирование справочника, т.к. индекс забыли добавить. Выполнение одного такого запроса не заметно, но т.к. этот запрос выполняется много раз, то по сумме затрат он выходит в топ 1.

Детали, почему запрос тормозит, можно увидеть тут же в файле с планом запроса (связь по номерам запросов).

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

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.7.540

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

См. также

Рефакторинг и качество кода Программист Бесплатно (free)

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

29.04.2026    301    _apelsin4ik    0    

3

Рефакторинг и качество кода Программист Стажер 1С 8.3 Бесплатно (free)

Код в 1С редко начинает тормозить сразу. Намного чаще он долго выглядит нормальным, а проблемы проявляются позже — когда растут данные, пользователи и количество доработок. В статье разбираю типичные причины такой деградации: запросы в цикле, лишние ПолучитьОбъект(), тяжёлые формы и обработку “по одному”. Статья практическая: с примерами, типичными ошибками и понятными признаками того, что код уже плохо масштабируется.

21.04.2026    1425    YA_2060655612    6    

11

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

Инструмент для тех, кто устал читать модули по 50 тысяч строк и искать ошибки глазами. MetaVision загружает выгруженные файлы конфигурации и за секунды строит графы функций, находит уязвимости и подсвечивает проблемы производительности. Ключевые возможности: Визуализация логики функций (графы условий, циклов, транзакций и вызовов). Статический аудит безопасности (RCE, SSRF, COM-инъекции, пароли в коде). Поиск проблем производительности (запросы в циклах, вложенные блокировки). Полнотекстовый поиск по всем модулям конфигурации. Статистика по объектам и функциям. Безопасность: Программа работает строго локально. Код вашей конфигурации не отправляется в интернет и не анализируется на сторонних серверах. Попробуйте MetaVision сегодня — узнайте, что скрывает ваш код.

20.04.2026    7560    778    KHoroshulinAV    48    

67

Рефакторинг и качество кода Программист 1С 8.3 Россия Бесплатно (free)

Как быстро разобраться в чужом коде? Как не забыть через полгода алгоритм работы своего собственного кода? Как наглядно проектировать? Ответам на эти вопросы посвящена данная публикация.

17.04.2026    528    chuprina_as    4    

4

Нейросети Рефакторинг и качество кода Программист Бесплатно (free)

Создадим скрипт на Пайтон, предназначенный для автоматизированного подбора чанков (фрагментов требований к коду) при разработке на 1С. Она помогает разработчику формировать качественные промпты для ИИ, включающие все необходимые требования безопасности, производительности и стандартов кодирования. Кому интересно, покритикуйте и предложите улучшения. Результаты опубликуем.

20.03.2026    1228    ksnik    4    

5

Нейросети Рефакторинг и качество кода Программист Бесплатно (free)

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

17.03.2026    1810    IgorVasilyev    54    

27

Рефакторинг и качество кода Программист 1С:Предприятие 8 1С:Комплексная автоматизация 2.х 1C:ERP Бесплатно (free)

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

09.02.2026    1898    Eugen-S    10    

5

Нейросети Рефакторинг и качество кода Программист Бесплатно (free)

В статье рассказываю, как писать код 1С в VS Code с помощью бесплатных AI-моделей 🤖 Используем GLM-4.7 через Roocode + Cerebras (до 1 миллион токенов в день). Подключаем бесплатные MCP. Генерируем новый код и смотрим, как AI справляется с задачами.

06.02.2026    16228    Ibrogim    83    

52
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SerVer1C 1092 06.10.25 09:41 Сейчас в теме
Не информативно ни разу....
ixijixi; akR00b; +2 Ответить
4. Alex_Smolensky 114 07.10.25 14:06 Сейчас в теме
(1) добавил описание
2. akR00b 26 06.10.25 10:26 Сейчас в теме
Для ОФ будет работать?
3. Alex_Smolensky 114 06.10.25 11:17 Сейчас в теме
(2) реализовано только для управляемых форм, для обычных нет.
17. Alex_Smolensky 114 12.11.25 20:51 Сейчас в теме
(3) (2) реализовал и для обычных форм
5. ОператорПК 2 29.10.25 08:57 Сейчас в теме
Здравствуйте. По поводу "Сервер SQL хранит у себя данные по текущему состоянию и выполнению запросов" - а за какой период хранятся данные там? Для конфигураций без БСП не будет работать? На ОФ переписать - проблема (сколько времени по Вашим оценкам)?
6. Alex_Smolensky 114 29.10.25 09:50 Сейчас в теме
(5) согласно документации, счетчики хранятся с момента старта SQL сервера. Но на серверах, что у нас в компании, они сбрасываются 1-2 раза в сутки. Возможно, что это управляется настройками или скриптами.

Для обработки БСП не требуется, все что нужно есть внутри. Нужно было указать какую-нить конфигурацию.

Доработаю и для обычных форм, к началу следующей недели.
16. Alex_Smolensky 114 12.11.25 20:51 Сейчас в теме
(5) добавил работу в обычных формах
18. ОператорПК 2 14.11.25 13:08 Сейчас в теме
(16) Спасибо! Скачал! В обычных формах, в строке "driver={SQL Server};server=ИМЯ_СЕРВЕРА;Trusted_Connections=yes;database=ИМЯ_БАЗЫ" поменял Имя сервера (оно по IP адресу) и Имя базы примерно вот так: driver={SQL Server};server=Х.Х.Х.Х;Trusted_Connections=yes;database=Х Этого должно быть достаточно для подключения к СКЛ серверу?
19. Alex_Smolensky 114 14.11.25 13:10 Сейчас в теме
(18) если настройка доступа к SQL сделана по доменной записи, то достаточно. Если этого нет и доступ по логину и паролю, то нужно ввести строку с указанием логина и пароля
20. ОператорПК 2 14.11.25 13:29 Сейчас в теме
(19) сейчас у меня так: есть терминальный сервер с IP адресом у.у.у.у на нем установлена платформа 1С с него я захожу в 1С, Есть СКЛ сервер с IP адресом х.х.х.х, есть еще отдельно сервер 1С-Предприятия с IP адресом z.z.z.z -тут я без проблем через консоль 1С добавляю базы/удаляю и т.д. при этом например при добавлении базы я явно указывая учетку СКЛ сервера "sa" и пароль от нее... Тут на терминальном сервере в Вашей обработке я так понимаю тоже нужно где-то указать "sa" и пароль от нее? если "Да" то можете пульнуть пример? такой строки типа "driver={......... =ИМЯ_БАЗЫ"
21. Alex_Smolensky 114 14.11.25 13:32 Сейчас в теме
(20) sa - это скорее всего, пользователь сервера 1С. А тут нужен доступ к SQL серверу и там пользователь будет другой.
22. ОператорПК 2 14.11.25 14:20 Сейчас в теме
(21) нет. sa используется при подключении к SQL Management Studio. См вложение.
Прикрепленные файлы:
23. ОператорПК 2 15.11.25 10:16 Сейчас в теме
(21) Так что на счет примера строки подключения где были бы логин/пароль от SQL?
24. Alex_Smolensky 114 15.11.25 10:31 Сейчас в теме
(23) driver={SQL Server};server=ИМЯ_СЕРВЕРА;uid=ВАШ_ЛОГИН;pwd=ВАШ_ПАРОЛЬ;database=ИМЯ_БАЗЫ;
25. ОператорПК 2 15.11.25 18:07 Сейчас в теме
(24) Спасибо. Получилось. Найти в базе запрос конечно по тому, что в эксель выгружается как "ТекстЗапроса1С" - это прям целое искусство, тут все запросы делятся на два вида: что то найти трудно, что то не реально....
7. ОператорПК 2 29.10.25 13:41 Сейчас в теме
(5) Спасибо. А как то в целом "фильтровать" входящие запросы можно? Например брать только те что за последние пять дней или брать последних 100 тыс запросов?
8. ОператорПК 2 29.10.25 17:56 Сейчас в теме
(6) Спасибо. А как то в целом "фильтровать" входящие запросы можно? Например брать только те что за последние пять дней или брать последних 100 тыс запросов?
9. Alex_Smolensky 114 29.10.25 18:13 Сейчас в теме
(8) список запросов выводится в порядке убывания затрат SQL сервера, т.е. ищем топ 20 или топ 100 запросов, которые больше всего нагружают SQL сервер.
Суть обработки в том, что бы найти запросы, которые нужно исправить. Все остальные 100 тыс запросов смотреть не нужно.

Отвечая еще на предыдущий вопрос: Статистика может сбрасываться по отдельным запросам из-за изменения структуры таблиц.
10. ОператорПК 2 30.10.25 08:08 Сейчас в теме
(9) Как работает обработка в целом понятно. Не понятно как "фильтровать" нужное от не нужного. Например "День1": обработка выдала в топе 3 запроса которые дают "максимальные затраты СКЛ", программист корректирует работу с запросами: либо исправляет сами запросы либо уменьшает частоту их выполнения. "День 2": если ни как не скорректировать данные СКЛ (которые содержат статистику) то эти же 3 запроса опять выходят в ТОП т.к. накоплены они с "согласно документации, счетчики хранятся с момента старта SQL сервера.".... Что делать программисту, он даже не в силах оценить помогли его доработки или нет? Очевидно что либо как то принудительно сбрасывать статистику в "День 1" либо что ИМХО правильней - иметь возможность при обращении к СКЛ брать данные "за период" ("за вчера" или за "пять дней последних" или "за сегодня") или хотя бы "сказать" СКЛ что меня статистика от момента старта не интересует, "дай статистику за последние 10 тыс. запросов".
11. Alex_Smolensky 114 30.10.25 12:03 Сейчас в теме
(10) Данная статистика формируется SQL итогово и связана с кэшем планов запроса. Если Запрос изменен - это уже другой запрос и план другой. В описанном случае, как понять, что программист исправил запрос - стоит обратить внимание на дату последнего вызова.
Старый запрос больше не будет выполняться и если новый в статистику не попадет - значит все исправлено.
Данные по старому запросу уйдут из кэша за 1-2 дня и из статистики то же исчезнут.
У SQL есть вот такой механизм, как описал выше. А вот как получить данные за 5 или 10 дней я не знаю.
В своей работе, а нахожу запросы, правлю и они уходят из отчета через день-два. Эта обработка для этого.
12. ОператорПК 2 30.10.25 16:23 Сейчас в теме
(11) А СКЛ нужно как настраивать чтобы работало "Данные по старому запросу уйдут из кэша за 1-2 дня и из статистики то же исчезнут."? Просто ранее Вы писали "согласно документации, счетчики хранятся с момента старта SQL сервера".
13. Alex_Smolensky 114 31.10.25 09:32 Сейчас в теме
(12) Если план запроса из кэша не уйдет, то он будет храниться с начала старта сервера.
14. ОператорПК 2 31.10.25 13:40 Сейчас в теме
(13) как то можно управлять "уходом плана запроса из кеша"?
15. Alex_Smolensky 114 31.10.25 14:45 Сейчас в теме
(14) тут я не подскажу, не на столько хорошо я знаком с SQL
26. Alex_Smolensky 114 05.03.26 12:14 Сейчас в теме
Схема системных таблиц SQL 2012.
Прикрепленные файлы:
SQL_Server_2012_System_Views_Map.pdf
Для отправки сообщения требуется регистрация/авторизация