之前曾簡介 MS-SQL 中的索引 (Index) 與常見類別,今天要繼續介紹設計索引的原則。
設計索引的原則
- 索引使用到的欄位應盡量的少,以減少 Insert, Update, Delete 和 Merge 指令調整索引導致的效能影響,以及使用的磁碟空間。
- 索引適合建立在常讀取 (Select),但不常增修的大量資料表,以增進讀取的效能。
- 如果檢視 View 包含資料表連接 (Join)、彙總函數 (ex. SUM),使用索引可以增進讀取的效能。
- 盡量使用 SARGable 的查詢語法,以有效的利用索引。(可參考拙作的一部分說明: SQL Not Equal 的效能影響)
- 盡量一次 (指令) 就完成 Insert 或 Update,才能利用到最佳化的索引維護方式。
以上改寫自官方的設計指南。