复合索引(组合索引)

本文介绍了复合索引的概念及其在数据库查询中的应用。探讨了复合索引如何提升多字段查询的速度,并提供了使用复合索引的最佳实践建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用户可以在多个列上建立索引,这种索引叫做复合索引(组合索引)。

 

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),对于效率有一定的提高。

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值