Hoje precisei obter os planos de execução e parâmetros da consulta de uma procedure em um banco de dados. Gostaria de compartilhar com vocês esse script que obtive de um colega de trabalho.
Fiz um teste aqui para mostrar a vocês eu executei a procedure dbo.uspGetEmployeeManagers na base de dados utilizando o parâmetro (10) na base AdventureWorks2014.
EXEC uspGetEmployeeManagers @BusinessEntityID = 60
Após a execução do comando acima, execute o comando abaixo:
DECLARE @dbname nvarchar(256),
@procname nvarchar(256)
SELECT @dbname = 'AdventureWorks2014',
@procname = 'dbo.uspGetEmployeeManagers'
; WITH basedata AS (
SELECT qs.statement_start_offset/2 AS stmt_start,
qs.statement_end_offset/2 AS stmt_end,
est.encrypted AS isencrypted, est.text AS sqltext,
epa.value AS set_options, qp.query_plan,
charindex('<ParameterList>', qp.query_plan) + len('<ParameterList>')
AS paramstart,
charindex('</ParameterList>', qp.query_plan) AS paramend
FROM sys.dm_exec_query_stats qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) est
CROSS APPLY sys.dm_exec_text_query_plan(qs.plan_handle,
qs.statement_start_offset,
qs.statement_end_offset) qp
CROSS APPLY sys.dm_exec_plan_attributes(qs.plan_handle) epa
WHERE est.objectid = object_id (@procname)
AND est.dbid = db_id(@dbname)
AND epa.attribute = 'set_options'
), next_level AS (
SELECT stmt_start, set_options, query_plan,
CASE WHEN isencrypted = 1 THEN '-- ENCRYPTED'
WHEN stmt_start >= 0
THEN substring(sqltext, stmt_start + 1,
CASE stmt_end
WHEN 0 THEN datalength(sqltext)
ELSE stmt_end - stmt_start + 1
END)
END AS Statement,
CASE WHEN paramend > paramstart
THEN CAST (substring(query_plan, paramstart,
paramend - paramstart) AS xml)
END AS params
FROM basedata
)
SELECT set_options AS [SET], n.stmt_start AS Pos, n.Statement,
CR.c.value('@Column', 'nvarchar(128)') AS Parameter,
CR.c.value('@ParameterCompiledValue', 'nvarchar(128)') AS [Sniffed Value],
CAST (query_plan AS xml) AS [Query plan]
FROM next_level n
CROSS APPLY n.params.nodes('ColumnReference') AS CR(c)
ORDER BY n.set_options, n.stmt_start, Parameter
Você obterá um resultado parecido com esse:
No caso você querendo saber qual os parâmetros estão guardados para a sua procedure, então você deverá mudar os valores das variáveis @dbname e @procname.
Outra forma de obter essa informação é olhando o xml do plano de execução da sua procedure, no fim do plano de execução você encontrará quais são os valores das variáveis na tag <ParameterList>. Para abrir o xml basta clicar no plano de execução com o botão direito e selecionar Show Execution Plan XML…
Outra forma também para descobrir os parâmetros de execução basta clicar também com o botão direito do mouse e selecionar properties e verá algo bem parecido com a imagem abaixo.
A vantagem que esse script te vai te proporcionar é que você poderá ver múltiplos planos de execução para uma determinada procedure. E quais são os parâmetros que estão sendo utilizados.
Content⃣ Kann ich im Casino mit PaysafeCard schon ab 5 oder 10 Euro einzahlen?There are…
Лучшие бонусы: какие игры есть в казино Мостбет для новых игроков?Казино Мостбет привлекает новых игроков…
Co byste měli vědět před návštěvou nového českého online casina?Pokud zvažujete návštěvu nového českého online…
Dans le monde en constante évolution des jeux d’argent en ligne, comprendre les mécanismes et…
In recent years, the landscape of online slot gaming has undergone a transformative evolution. Developers…
Einführung: Die Evolution des digitalen Glücksspiels Die Welt des Online-Glücksspiels befindet sich in ständigem Wandel.…