時間:2024-03-26 14:33作者:下載吧人氣:30
SQL Server 在處理存儲過程的時候,為了節(jié)省編譯時間,是一次編譯,多次重用。當(dāng)?shù)谝淮芜\行時代入值產(chǎn)生的執(zhí)行計劃,不適用后續(xù)代入的參數(shù)時,就產(chǎn)生了parameter sniffing問題。 create procedure Sniff1(@i int) as SELECT count(b.SalesOrderID),sum(p.weight) from [Sale
SQL Server 在處理存儲過程的時候,為了節(jié)省編譯時間,是一次編譯,多次重用。當(dāng)?shù)谝淮芜\行時代入值產(chǎn)生的執(zhí)行計劃,不適用后續(xù)代入的參數(shù)時,就產(chǎn)生了parameter sniffing問題。
create procedure Sniff1(@i int) as
SELECT count(b.SalesOrderID),sum(p.weight) from
[Sales].[SalesOrderHeader] a
inner join [Sales].[SalesOrderDetail] b
on a.SalesOrderID = b.SalesOrderID
inner join Production.Product p
on b.ProductID = p.ProductID
where a.SalesOrderID =@i;
go
DBCC FREEPROCCACHE
exec Sniff1 50000;
exec Sniff1 75124;
go
網(wǎng)友評論