新聞中心
SQL Server數(shù)據(jù)庫中,存儲過程的執(zhí)行總是要比SQL語句直接執(zhí)行要慢,這究竟是為什么呢?本文將帶您尋找答案。

成都創(chuàng)新互聯(lián)公司專注于圖們網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供圖們營銷型網(wǎng)站建設(shè),圖們網(wǎng)站制作、圖們網(wǎng)頁設(shè)計(jì)、圖們網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造圖們網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供圖們網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
在SQL Server中有一個(gè)叫做 “Parameter sniffing”的特性。SQL Server在存儲過程執(zhí)行之前都會制定一個(gè)執(zhí)行計(jì)劃。在上面的例子中,SQL在編譯的時(shí)候并不知道@thedate的值是多少,所以它在執(zhí)行執(zhí)行計(jì)劃的時(shí)候就要進(jìn)行大量的猜測。假設(shè)傳遞給@thedate的參數(shù)大部分都是非空字符串,而FACT表中有40%的thedate字段都是null,那么SQL Server就會選擇全表掃描而不是索引掃描來對參數(shù)@thedate制定執(zhí)行計(jì)劃。全表掃描是在參數(shù)為空或?yàn)?的時(shí)候最好的執(zhí)行計(jì)劃。但是全表掃描嚴(yán)重影響了性能。
假設(shè)你第一次使用了Exec pro_ImAnalysis_daily @thedate=’20080312’那么SQL Server就會使用20080312這個(gè)值作為下次參數(shù)@thedate的執(zhí)行計(jì)劃的參考值,而不會進(jìn)行全表掃描了,但是如果使用@thedate=null,則下次執(zhí)行計(jì)劃就要根據(jù)全表掃描進(jìn)行了。
有兩種方式能夠避免出現(xiàn)“Parameter sniffing”問題:


咨詢
建站咨詢
