|
sp_executesql добавляет много времени на выполнение
|
|||
---|---|---|---|
#18+
С использованием exec sp_executesql задумывается на 23 секунды, тот же запрос без нее выполняется за 7 секунд. Это лечится? P.S. Вопрос за надобностью EF C#: там любой запрос упаковывается в sp_executesql, я прямиком через SSMS сверил время... ... |
|||
:
Нравится:
Не нравится:
|
|||
08.03.2021, 23:52 |
|
sp_executesql добавляет много времени на выполнение
|
|||
---|---|---|---|
#18+
sanekoffice там любой запрос упаковывается в sp_executesql 99% клиентских приложений оборачивают свои обращения к MSSQL в sp_executesql. Разница во времени выполнения - наверное, что-то связанное с parameter sniffing. Вот здесь подробно: http://www.queryprocessor.ru/fast-in-ssms-slow-in-app-part1/ ... |
|||
:
Нравится:
Не нравится:
|
|||
09.03.2021, 06:07 |
|
sp_executesql добавляет много времени на выполнение
|
|||
---|---|---|---|
#18+
Сон Веры Павловны , речь также может идти о компиляции. Например, запрос в sp_executesql формируется не как параметризованный, а конкатенацией в строку, типа "Select * from ... Where a=" + @id + ... ". В этом случае, разумеется, кешированным планом воспользоваться не получится практически никогда, и если запрос - сложный, он может компилиться долго. ... вряд ли, конечно, 23 секунды, но фиг его знает, какая там загруженность процессоров, статистики и т.д. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.03.2021, 08:06 |
|
sp_executesql добавляет много времени на выполнение
|
|||
---|---|---|---|
#18+
uaggster Например, запрос в sp_executesql формируется не как параметризованный, а конкатенацией в строку, типа "Select * from ... Where a=" + @id + ... ". Я обычно по умолчанию стараюсь думать о людях хорошо :) ... |
|||
:
Нравится:
Не нравится:
|
|||
09.03.2021, 09:10 |
|
|
start [/forum/topic.php?fid=46&fpage=32&tid=1684991]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
56ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
40ms |
get tp. blocked users: |
1ms |
others: | 300ms |
total: | 439ms |
0 / 0 |