- 取得連結
- X
- 以電子郵件傳送
- 其他應用程式
本篇文章將建立多個欄位的索引,並透過篩選不同欄位來比較執行計畫的差異
使用 AdventureWorks2017 作為範例資料庫
並已 Sales.SalesOrderDetail 資料表為基礎透過迴圈重複匯入建立多筆資料列的資料表內容
此文章僅記錄不同查詢的執行計畫結果,並不會描述紀錄內容問題的解決方式
檢視資料表結構與內容
資料表筆數為 1213,1700
data:image/s3,"s3://crabby-images/c6a2b/c6a2b6d22a6b92323a4d878cd9c1ee571002afe4" alt=""
data:image/s3,"s3://crabby-images/27502/2750214faadeda6e5e90b5e0d988061bfa026194" alt=""
建立 ProductID 與 UnitPrice 的非叢集索引,並將 ProductID 順序放在前面
data:image/s3,"s3://crabby-images/857c2/857c21ff99dd0746170714b48552d5e9fcc44275" alt=""
檢視查詢與實際執行計畫
先使用 ProductID 作為篩選條件進行查詢
SELECT TOP(1000) [ProductID]
,[UnitPrice]
FROM [Sales].[SalesOrderDetailForIndex]
WHERE [ProductID] = 775
此查詢的執行計畫如下
data:image/s3,"s3://crabby-images/0f594/0f594252640813190317992839bf10ebdd991aaf" alt=""
使用 ProductID 進行查詢時,會對索引進行索引搜尋 (Index Seek)
接下來使用 UnitPrice 作為篩選條件
SELECT TOP(1000) [ProductID]
,[UnitPrice]
FROM [Sales].[SalesOrderDetailForIndex]
WHERE [UnitPrice] = 843.7475
此查詢的執行計畫如下
data:image/s3,"s3://crabby-images/c66d2/c66d20c40347f0877e862ee3c4b079d3c9a07e41" alt=""
雖然 UnitPrice 欄位有建立索引
但執行計畫結果是對索引進行索引掃描 (Index Scan)
花費的時間成本相較索引搜尋 (Index Seek) 之下是較高的
取得全部資料列時
若沒有指定 TOP 關鍵字進行 UnitPrice 欄位篩選時
執行計畫會建議要建立 UnitPrice 欄位的索引內容
data:image/s3,"s3://crabby-images/cc14d/cc14daada8623456425690ce9a0f9166a10429ae" alt=""
data:image/s3,"s3://crabby-images/0d1fe/0d1fe170df8d5e40e18c4c92a3d6e96dca2c83e8" alt=""
參考資料
本文章僅做為紀錄支用並無相關參考內容
留言
張貼留言