概要
什麼是單一索引,什麼又是複合索引呢? 何時建立複合索引,複合索引又需要注意些什麼呢?本篇文章主要是對網上一些討論的總結。
一.概念
單一索引是指索引列為一列的情況,即建立索引的語句只實施在一列上。
使用者可以在多個列上建立索引,這種索引叫做複合索引(複合式索引)。複合索引的建立方法與建立單一索引的方法完全一樣。但複合索引在資料庫操作期間所需的開銷更小,可以代替多個單一索引。當表的行數遠遠大於索引鍵的數目時,使用這種方式可以明顯加快表的查詢速度。
同時有兩個概念叫做窄索引和寬索引,窄索引是指索引列為1-2列的索引,如果不特殊說明的話一般是指單一索引。寬索引也就是索引列超過2列的索引。
設計索引的一個重要原則就是能用窄索引不用寬索引,因為窄索引往往比複合式索引更有效。擁有更多的窄索引,將給最佳化程式提供更多的選擇餘地,這通常有助於提高效能。
二.使用
建立索引
create index idx1 on table1(col1,col2,col3)
查詢
select * from table1 where col1= A and col2= B and col3 = C
這時候查詢最佳化工具,不在掃描表了,而是直接的從索引中拿資料,