mysql索引的使用详解

一、 普通索引

ALTER TABLE `表名` ADD INDEX index_store_id索引名 ( `字段名` ) 

二、唯一索引
它与前面的"普通索引"类似,不同的就是:索引列的值必须唯一,但允许有空值。

ALTER TABLE `table_name` ADD UNIQUE (`column`)

三、 组合索引

 ALTER TABLE  `table_name`  ADD INDEX `idx_storeid_tpmactivecode` (`store_id`,`tpm_active_code`)

在组合索引中有一个重要的概念:引导列(leading column),在上面的例子中,store_id列为引导列。

1、组合索引:当我们进行查询时where 限制条件必须有引导列,索引才会生效。
例:
1)where store_id=
2)where store_id= and tpm_active_code=
3)where tpm_active_code= and store_id=
在这里插入图片描述
ref : 根据普通索引等值匹配
2、不会使用该索引(where 条件中没有引导列)
where tpm_active_code= ”查询就不会使用该索引。
所以限制条件中包含先导列时,该限制条件才会使用该组合索引。
在这里插入图片描述
ALL: 全表扫描,直接扫描主键索引,这种访问方式称为all。那说明这条查询语句遍历了所有的行,并没有使用到索引。

四、查看索引

show index from `table_name`;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值