Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 24.03.2010
Сообщений: 18

Sql странное поведение при выполнение хранимой процедуры

25.09.2020, 13:02. Показов 854. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ситуация следующая , столкнулся с ней уже два раза за два месяца (процедуре больше 3 лет и за это время такого не наблюдалось ). Есть хранимая процедура вызов ее осуществляется через
SqlCommand C# , все работает нормально , выполнение происходит мгновенно , но в один прекрасный день она начинает странно реагировать , на определенный набор параметров она начинает грузить процессор и вылетать по таймауту, причем если подсоединиться к точно копии этой базы на другой виртуальной машине все нормально или если напрямую вызвать эту процедуру через exect на сервере тоже все выполняется мгновенно но не через SqlCommand . Помогает только перезагрузка виртуалки с sql.
Если через profiler взять строку запроса процедуры с параметрами которая приходит с C# на сервер и вставить напрямую в sql то она выполниться мгновенно. Я не могу понять из-за чего это может быть
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.09.2020, 13:02
Ответы с готовыми решениями:

Выполнение хранимой процедуры sql в windows forms C#
Здравствуйте ! помогите люди добрые:) подскажите как выполнить хранимую процедуру sql в windows forms C#. Например при нажатии на...

Странное поведение запроса в хранимой процедуре
Всем мир! Имею такой запрос на удаление. DELETE FROM tbl_clicks WHERE id IN ( SELECT * FROM ( SELECT id FROM tbl_clicks ...

MS SQL Неправильное имя хранимой процедуры при подключении из Access
Подключаюсь к MS SQL 2000 из MS Access 2000 (adp-проект). В окне 'хранимые процедуры' вижу примерно такую вещь: ...

4
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
25.09.2020, 13:19
Процедуры компилируются, если в кеше планов нет ее плана. Или перекомпилируется, если это требуется в виду изменения статистик и т.п.
При компиляции для построения плана используются значения параметров.
Соответственно, при дальнейших вызовах с другими значениями параметров, построенный план может быть не оптимальным.
Если хотите подробнее - гуглите "parameters sniffing".

Способов лечения много и выбор зависит как от текста процедуры, так и от данных в таблицах.
Если нет желания заморачиваться и разбираться - просто пересоздайте процедуру с опцией recompile.
0
0 / 0 / 0
Регистрация: 24.03.2010
Сообщений: 18
25.09.2020, 13:34  [ТС]
invm, я об этом думал но меня смутило, что
SQL
1
EXEC dbo.GetResultByTableTemplates @leftObjectID=101467,@ObjectType=111
из Microsoft SQL Server Management Studio проходит нормально , а при вызове через SqlCommand виснет намертво.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
25.09.2020, 13:55
Цитата Сообщение от Wepr Посмотреть сообщение
из Microsoft SQL Server Management Studio проходит нормально , а при вызове через SqlCommand виснет намертво.
План зависит от некоторых опций соединения.
У вас они разные для соединений из приложения и из студии. Поэтому в кеше для процедуры несколько планов.
Изучайте - http://www.queryprocessor.ru/f... app-part1/
2
0 / 0 / 0
Регистрация: 24.03.2010
Сообщений: 18
25.09.2020, 14:38  [ТС]
invm, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.09.2020, 14:38
Помогаю со студенческими работами здесь

Выполнение хранимой процедуры из SQL
Всем привет. Возникла проблема при выполнении хранимой процедуры. Я добавил на форму компоненты sqlConnection и sqlCommand. У sqlConnection...

Странное поведение при сохранении через LINQ в MS SQL Server
Добрый день! Есть код: using System; using System.Collections.Generic; using System.Linq; using System.Text; using...

Выполнение хранимой процедуры
Приветствую! Есть хранимая процедура: procedure P_find 2 ( 3 n1 in number, -- регистрационный номер 4 n2 ...

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

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru