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

12.11.25

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

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

Файлы

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

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

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

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

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

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

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

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

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

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

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

 

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

 

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

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

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

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

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

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

См. также

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

Костыль, рефакторинг или архитектура - делюсь своим видением того, как выбирать правильный инструмент под конкретную задачу. За годы в 1С я выработал алгоритм "трех зон", который помогает мне не только писать код, но и говорить с бизнесом на его языке. В статье рассказываю, когда временное решение оправдано, а когда оно становится миной замедленного действия. Никаких нотаций, только мой опыт принятия решений, где каждая строчка имеет цену. Буду рад, если моя система поможет вам по-новому взглянуть на привычную рутину.

19.12.2025    1595    GarriSoft    14    

17

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

История о легендарном отчете на 11 000 строк, копеечном расхождении и костыле 2014 года, который пережил все обновления. О том, как Василий спас квартальное закрытие, не тронув ни единой строчки кода монолита

15.12.2025    1240    GarriSoft    21    

20

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

ИИ для код-ревью – не просто модный тренд, а реальный инструмент, который уже помогает разработчикам экономить время и повышать качество кода. В статье разбираемся, как запустить локальную LLM на базе Ollama, подключить ее к Git через Webhook и Python-скрипт, а также какие параметры модели отвечают за точность и галлюцинации. Делимся схемой работы, настройками и результатами тестирования, доказывая, что автоматизированное код-ревью действительно может работать – даже без космического бюджета.

30.10.2025    4396    user2100900    4    

17

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

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

28.10.2025    5107    vaillant    35    

16

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

С ростом качества работы нейросетей и упрощением их интеграции мы решили попробовать внедрить их в процессы обновления 1С. За последний год через сервис обновлений нетиповых конфигураций 1С нашей компании прошло порядка пяти тысяч проектов, четверть из которых включала расширения. Автоматизацию обновления расширений — в частности, методов модулей расширений — мы выбрали в качестве первого шага. В этой статье расскажем про настройку модели и промпта исходя из поставленной задачи и как нейросеть помогла сократить затраты на реальных проектах.

24.10.2025    3003    1c-izh    6    

8

Обновление 1С Рефакторинг и качество кода Механизмы платформы 1С 1С 8.3 Отраслевые 1С:Бухгалтерия 3.0 1С:ERP Управление предприятием 2 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 1С:Розница 3.0 1С:Документооборот Абонемент ($m)

Конфигурация "Анализ конфигураций (версия 5)" - позволяет проверять любые конфигурации, расширения, отчеты и обработки на наличие ошибок, связанных с вызовом экспортных функций и процедур общих модулей и модулей менеджеров объектов. Проверяются ошибки: 1) Метод объекта не обнаружен 2) Недостаточно фактических параметров. 3) Слишком много фактических параметров. Рекомендуется выполнять при подготовке обновлений. Анализ расширений - позволяет выводить подробный количественный состав расширений по объектам, определить случаи пересечения одного и того же функционала в разных расширения, выявить использование в модулях аннотации "вместо".

10 стартмани

17.10.2025    6019    33    Suker86    18    

21

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

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

23.09.2025    7830    AlexeyPROSTO_1C    1    

17

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

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

02.09.2025    3207    user1827916    1    

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

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

Доработаю и для обычных форм, к началу следующей недели.
16. Alex_Smolensky 112 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 112 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 112 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 112 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 112 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 112 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 112 31.10.25 09:32 Сейчас в теме
(12) Если план запроса из кэша не уйдет, то он будет храниться с начала старта сервера.
14. ОператорПК 2 31.10.25 13:40 Сейчас в теме
(13) как то можно управлять "уходом плана запроса из кеша"?
15. Alex_Smolensky 112 31.10.25 14:45 Сейчас в теме
(14) тут я не подскажу, не на столько хорошо я знаком с SQL
Для отправки сообщения требуется регистрация/авторизация