SQL?Server索引查找/掃描沒有出現(xiàn)key?lookup的案例機械
在我們講解這個案例前,我們先來了解/預熱一下SQL Server的兩個概念:鍵查找(key lookup)和RID查找(RID lookup),通常,當查詢優(yōu)化器使用非聚集索引進行查找時,如果所選擇的列或查詢條件中的列只部分包含在使用的非聚集索引和聚集索引中時,就需要一個查找(lookup)來檢索其他字段來滿足請求。對一個有聚簇索引的表來說是一個鍵查找(key lookup),對一個堆表來說是一個RID查找(RID lookup),這種查找即是——書簽查找(bookmark lookup)。在其他數(shù)據(jù)庫概念中,可能又叫回表查詢之類的概念。
那么我們先來構(gòu)造案例所需的測試環(huán)境。下面測試環(huán)境為SQL Server 2014。
SELECT * INTO TEST FROM SYS.OBJECTS CREATE CLUSTERED INDEX PK_TEST ON TEST(OBJECT_ID, NAME,CREATE_DATE) CREATE INDEX IX_TEST_N1 ON TEST(PARENT_OBJECT_ID, TYPE) UPDATE STATISTICS TEST WITH FULLSCAN;
如上所示,表TEST在字段OBJECT_ID, NAME,CREATE_DATE建立了聚集索引,然后下面這種查詢語句,你查看其實際執(zhí)行計劃
SELECT OBJECT_ID, NAME,CREATE_DATE,PARENT_OBJECT_ID, TYPE FROM TEST WHERE PARENT_OBJECT_ID=2255213;
你會發(fā)現(xiàn),SQL Server優(yōu)化器走索引IX_TEST_N1查找就返回了所有數(shù)據(jù)。沒有書簽查找(回表查詢),那么這是為什么呢?朋友這樣問我的時候,我還真沒有想明白。難道索引IX_TEST_N1中也會存儲OBJECT_ID, NAME,CREATE_DATE的值? 當然你構(gòu)造其它的案例時,有可能是索引IX_TEST_N1掃描就返回了數(shù)據(jù)。不會發(fā)生書簽查找。
后面才想明白,非聚集索引中的索引行指向數(shù)據(jù)行的指針稱為行定位器。 行定位器的結(jié)構(gòu)取決于數(shù)據(jù)頁是存儲在堆中還是聚集表中。 對于堆,行定位器是指向行的指針。 對于聚集表,行定位器是聚集索引鍵。這是不是有點眼熟,類似于MySQL InnoDB的二級索引(Secondary Index)會自動補齊主鍵,將主鍵列追加到二級索引列后面。所以執(zhí)行計劃就走索引IX_TEST_N1查找就能返回數(shù)據(jù)了。根本不需要書簽查找(回表查詢)。如果查詢語句多一個字段或者是SELECT *的話,你就會看到書簽查找了。如下所示
到此這篇關(guān)于SQL Server索引查找/掃描沒有出現(xiàn)key lookup的案例淺析的文章就介紹到這了,更多相關(guān)SQL Server索引查找/掃描內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL SERVER 2012新增函數(shù)之字符串函數(shù)FORMAT詳解
這篇文章主要給大家介紹了關(guān)于SQL SERVER 2012新增函數(shù)之字符串函數(shù)FORMAT的相關(guān)資料,文中通過實例介紹的非常詳細,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03SQL Server誤區(qū)30日談 第10天 數(shù)據(jù)庫鏡像在故障發(fā)生后 馬上就能發(fā)現(xiàn)
市面上大肆宣傳數(shù)據(jù)庫鏡像技術(shù)可以在故障發(fā)生后,立即檢測到錯誤并進行故障轉(zhuǎn)移2013-01-01sqlserver中根據(jù)字符分割字符串的最好的寫法分享
因數(shù)據(jù)庫中保存的是以,號分隔的數(shù)據(jù),需要在界面上以表格的方式顯示出來。特想出以下方法2012-05-05SqlServer將查詢結(jié)果轉(zhuǎn)換為XML和JSON
這篇文章主要介紹了SqlServer將查詢結(jié)果轉(zhuǎn)換為XML和JSON的相關(guān)資料,需要的朋友可以參考下2017-07-07卸載VS2011 Developer Preview后Sql Server2008&nbs
話說上回我為了嘗嘗螃蟹的味道而裝了 VS2011 Developer Preview,但是裝完后立馬卸載掉了,原因是這家伙的安裝目錄位置沒用,我設置到D盤的但是裝完后D盤的文件夾只有一百多M,而足足8G+的空間是在C盤上消耗的。2011-11-11