91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL Server 2008處理隱式數據類型轉換的示例分析

發布時間:2021-09-15 16:01:43 來源:億速云 閱讀:149 作者:小新 欄目:MySQL數據庫

小編給大家分享一下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
)ID
-- 將 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

得到的查詢計劃預估行數如下圖所示

SQL Server 2008處理隱式數據類型轉換的示例分析

從圖中顯示的預估數據行數可以看到,對于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

結果如下圖所示:
SQL Server 2008處理隱式數據類型轉換的示例分析

不管是varchar,還是nvarchar的變量,預估的行數都是99.0099,這個值與使用nvarchar常量值的結果一樣,看來SQL Server查詢優化器應該確實把 GetRangeThroughConvert 的結果看成變量了,這個應該是設計上考慮不太周全的地方了,畢竟指定固定常量值的時候,GetRangeThroughConvert的結果應該也是確定值才對。

以上是“SQL Server 2008處理隱式數據類型轉換的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

石家庄市| 丹寨县| 岱山县| 加查县| 云浮市| 溧水县| 东丽区| 谷城县| 白玉县| 繁峙县| 江阴市| 濉溪县| 东丰县| 虎林市| 诸暨市| 北京市| 二手房| 芷江| 南丹县| 封丘县| 双鸭山市| 高陵县| 岑溪市| 石柱| 井冈山市| 成安县| 新昌县| 德格县| 陇西县| 萝北县| 桐城市| 凤山县| 大竹县| 靖安县| 社旗县| 湖北省| 三亚市| 灵石县| 长海县| 山阴县| 西宁市|