用户可以在多个列上建立索引,这种索引叫做复合索引(组合索引)。
1.何时是用复合索引
在where条件中字段用索引,如果用多字段就用复合索引。比如在查询地址的时候,经常要求输入省,市信息,如果同时在省,市上建立索引,将会提高查询速度。
2.对于复合索引,在查询使用时,最好将条件顺序按找索引的顺序,这样效率最高。如:
IDX1:create index idx1 on table1(col2,col3,col5)
"select * from table1 where col2=A and col3=B and col5=D" 索引效果明显
如果是"select * from table1 where col3=B and col2=A and col5=D"
或者是"select * from table1 where col3=B"将不会使用索引,或者效果不明显
3.复合索引会替代单一索引么?
复合索引IDX1:create index idx1 on table1(col1,col2) 单一索引IDX2:create index idx2 on table1(col1)
单一索引IDX2作为查询条件和复合索引IDX1作为查询条件的查询速度是几乎一样的,甚至比用复合索引IDX1还要略快(在查询结果集数目一样的情况下);而如果仅用复合聚集索引的非起始列(col2)作为查询条件的话,复合索引IDX1是不起任何作用的。对一张表来说,如果有一个复合索引 on (col1,col2),就没有必要同时建立一个单索引 on col1。如果查询条件需要,可以在已有单索引 on col1的情况下,添加复合索引on (col1,col2),对于效率有一定的提高。
单一索引IDX2作为查询条件和复合索引IDX1作为查询条件的查询速度是几乎一样的,甚至比用复合索引IDX1还要略快(在查询结果集数目一样的情况下);而如果仅用复合聚集索引的非起始列(col2)作为查询条件的话,复合索引IDX1是不起任何作用的。对一张表来说,如果有一个复合索引 on (col1,col2),就没有必要同时建立一个单索引 on col1。如果查询条件需要,可以在已有单索引 on col1的情况下,添加复合索引on (col1,col2),对于效率有一定的提高。