明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

SQL Server 2008 處理隱式數(shù)據(jù)分類轉(zhuǎn)換在執(zhí)行計(jì)劃中的增強(qiáng)

[摘要]通過如下測(cè)試驗(yàn)證,首先建立數(shù)據(jù)分布不平均的測(cè)試表。USE tempdb GOCREATE TABLE _t(c varchar(50) );CREATE INDEX IX_c ON _t( c );...
通過如下測(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'

然后通過 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,這說明預(yù)估并沒有考慮我們指定的值。
進(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é)果一樣,看來SQL Server查詢優(yōu)化器應(yīng)該確實(shí)把 GetRangeThroughConvert 的結(jié)果看成變量了,這個(gè)應(yīng)該是設(shè)計(jì)上考慮不太周全的地方了,畢竟指定固定常量值的時(shí)候,GetRangeThroughConvert的結(jié)果應(yīng)該也是確定值才對(duì)。

本文講解了SQL Server的相關(guān)內(nèi)容,更多相關(guān)內(nèi)容請(qǐng)關(guān)注php中文網(wǎng)。

相關(guān)推薦:

如何讓MySQL中單句實(shí)現(xiàn)無限層次父子關(guān)系查詢

帶進(jìn)度的SQL Server FileStream如何存取

當(dāng)忘記 SQL Server 管理員密碼該如何處理

以上就是SQL Server 2008 處理隱式數(shù)據(jù)類型轉(zhuǎn)換在執(zhí)行計(jì)劃中的增強(qiáng)的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識(shí)。