小編給大家分享一下SQL Server 2008處理隱式數(shù)據(jù)類型轉(zhuǎn)換的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
網(wǎng)站的建設(shè)成都創(chuàng)新互聯(lián)公司專注網(wǎng)站定制,經(jīng)驗(yàn)豐富,不做模板,主營(yíng)網(wǎng)站定制開(kāi)發(fā).小程序定制開(kāi)發(fā),H5頁(yè)面制作!給你煥然一新的設(shè)計(jì)體驗(yàn)!已為會(huì)所設(shè)計(jì)等企業(yè)提供專業(yè)服務(wù)。通過(guò)如下測(cè)試驗(yàn)證,首先建立數(shù)據(jù)分布不平均的測(cè)試表。
USE tempdb GOCREATE TABLE _t( c varchar(50) );CREATE INDEX IX_c ON _t( c );GO-- 加入 10000 條數(shù)據(jù)INSERT _tSELECT (9999 + id) FROM( SELECT TOP 10000 id = ROW_NUMBER() OVER( ORDER BY GETDATE() ) FROM sys.all_columns a, sys.all_columns )ID -- 將 100 - 10000 的數(shù)據(jù)變成相同值UPDATE _t SET c = '' WHERE c >= '10100'
然后通過(guò) varhcar和nvarchar值分別測(cè)試滿足條件1條和滿足條件8900條的執(zhí)行計(jì)劃預(yù)估行數(shù)。
ALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = '10005'; -- 實(shí)際1條GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = N'10005'; -- 實(shí)際1條GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = ''; -- 實(shí)際9900條GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = N''; -- 實(shí)際9900條GOSET SHOWPLAN_ALL OFF;GO
得到的查詢計(jì)劃預(yù)估行數(shù)如下圖所示
從圖中顯示的預(yù)估數(shù)據(jù)行數(shù)可以看到,對(duì)于varchar值(不需要隱匿的數(shù)據(jù)類型轉(zhuǎn)換),其預(yù)估的結(jié)果是準(zhǔn)確的。但對(duì)于nvarchar值,不管指定的值是只有一條數(shù)據(jù),還是有8900條數(shù)據(jù)匹配,其預(yù)估的結(jié)果都是99.0099,這說(shuō)明預(yù)估并沒(méi)有考慮我們指定的值。
進(jìn)一步用變量測(cè)試
ALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGODECLARE @v varchar;SELECT * FROM _t WHERE c = @v; -- varcharGOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGODECLARE @nv nvarchar;SELECT * FROM _t WHERE c = @nv; -- nvarcharGOSET SHOWPLAN_ALL OFF;GO
結(jié)果如下圖所示:
不管是varchar,還是nvarchar的變量,預(yù)估的行數(shù)都是99.0099,這個(gè)值與使用nvarchar常量值的結(jié)果一樣,看來(lái)SQL Server查詢優(yōu)化器應(yīng)該確實(shí)把 GetRangeThroughConvert 的結(jié)果看成變量了,這個(gè)應(yīng)該是設(shè)計(jì)上考慮不太周全的地方了,畢竟指定固定常量值的時(shí)候,GetRangeThroughConvert的結(jié)果應(yīng)該也是確定值才對(duì)。
以上是“SQL Server 2008處理隱式數(shù)據(jù)類型轉(zhuǎn)換的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站制作公司行業(yè)資訊頻道!