共計 1664 個字符,預計需要花費 5 分鐘才能閱讀完成。
丸趣 TV 小編給大家分享一下 SQL Server 2008 處理隱式數據類型轉換的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
通過如下測試驗證,首先建立數據分布不平均的測試表。
USE tempdb
GOCREATE TABLE _t( c varchar(50)
);CREATE INDEX IX_c ON _t( c );GO-- 加入 10000 條數據 INSERT _tSELECT (9999 + id) FROM( SELECT TOP 10000 id = ROW_NUMBER() OVER( ORDER BY GETDATE() ) FROM sys.all_columns a, sys.all_columns
-- 將 100 - 10000 的數據變成相同值 UPDATE _t SET c = WHERE c = 10100
然后通過 varhcar 和 nvarchar 值分別測試滿足條件 1 條和滿足條件 8900 條的執行計劃預估行數。
ALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = 10005 -- 實際 1 條 GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = N 10005 -- 實際 1 條 GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = -- 實際 9900 條 GOSET SHOWPLAN_ALL OFF;GOALTER INDEX IX_c ON _t REBUILD;GOSET SHOWPLAN_ALL ONGOSELECT * FROM _t WHERE c = N -- 實際 9900 條 GOSET SHOWPLAN_ALL OFF;GO
得到的查詢計劃預估行數如下圖所示
從圖中顯示的預估數據行數可以看到,對于 varchar 值(不需要隱匿的數據類型轉換),其預估的結果是準確的。但對于 nvarchar 值,不管指定的值是只有一條數據,還是有 8900 條數據匹配,其預估的結果都是 99.0099,這說明預估并沒有考慮我們指定的值。
進一步用變量測試
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
結果如下圖所示:
不管是 varchar,還是 nvarchar 的變量,預估的行數都是 99.0099,這個值與使用 nvarchar 常量值的結果一樣,看來 SQL Server 查詢優化器應該確實把 GetRangeThroughConvert 的結果看成變量了,這個應該是設計上考慮不太周全的地方了,畢竟指定固定常量值的時候,GetRangeThroughConvert 的結果應該也是確定值才對。
以上是“SQL Server 2008 處理隱式數據類型轉換的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注丸趣 TV 行業資訊頻道!