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=
mysql索引的使用详解_第1张图片
ref : 根据普通索引等值匹配
2、不会使用该索引(where 条件中没有引导列)
where tpm_active_code= ”查询就不会使用该索引。
所以限制条件中包含先导列时,该限制条件才会使用该组合索引。
mysql索引的使用详解_第2张图片
ALL: 全表扫描,直接扫描主键索引,这种访问方式称为all。那说明这条查询语句遍历了所有的行,并没有使用到索引。

四、查看索引

show index from `table_name`;

你可能感兴趣的:(笔记,mysql,数据库)