MySQL索引介绍和实战

时间:2020-07-29 10:02:38   收藏:0   阅读:66

索引是什么

MySQL官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。

可以得到索引的本质:索引是数据结构,索引的目的是提高查询效率,可以类比英语新华字典,根据目录定位词语

如果没有目录呢,就需要从A到Z,去遍历的查找一遍,一个一个找和直接根据目录定位到数据,差的就是天壤之别

 

索引底层数据结构

数据库除了存储数据本身之外,还维护着一个满足特定查找算法的数据结构,这些结构以某种方式指向数据,这样就可以基于这些数据结构实现高效查找算法。这种结构就是索引,MySQL中索引是B+树实现的,每个索引都对应一棵B+树

技术图片

 

索引的优势

索引的劣势

索引语法

以test_user表为例,建表sql如下

CREATE TABLE `test_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 主键id,
  `user_id` varchar(36) NOT NULL COMMENT 用户id,
  `user_name` varchar(30) NOT NULL COMMENT 用户名称,
  `phone` varchar(20) NOT NULL COMMENT 手机号码,
  `lan_id` int(9) NOT NULL COMMENT 本地网,
  `region_id` int(9) NOT NULL COMMENT 区域,
  `create_time` datetime NOT NULL COMMENT 创建时间,
  PRIMARY KEY (`id`),
  KEY `idx_user_id` (`user_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1010001 DEFAULT CHARSET=utf8mb4;

 

 1.查看索引:SHOW INDEX FROM table_name\G

SHOW INDEX FROM test_user;

技术图片

 

 

2.删除索引:DROP INDEX [indexName] ON mytable;

DROP INDEX idx_user_id ON test_user;

技术图片

 

 

3.创建索引 alter tableName add [unique] index [indexName] on (columnName (length) )

ALTER TABLE test_user ADD INDEX idx_user_id(user_id);

技术图片

 

 

哪些情况需要建索引

哪些不适合建索引

 

索引实战

我们在test_user表中有100万数据

技术图片

 

 

优化一:使用全部索引

1.不加索引,关闭缓存查一条数据

SELECT SQL_NO_CACHE * FROM `test_user` WHERE phone=15190427892 AND lan_id=317 AND region_id=92

技术图片

 

2.加一条复合索引

ALTER TABLE test_user ADD INDEX idx_phone_lan_region(phone,lan_id,region_id);

再查一次,看结果

技术图片

 

 可以看到,加了索引以后,查询效率提高了很多

这里我们建立的复合索引包含的3个字段,查询的时候全部用到了,而且where中的条件严格按照索引顺序,这样查询效率是最高的

我们使用EXPLAIN关键字看一下

技术图片

 

优化二:最左前缀法则

我们把上面那个例子的第一个插件条件删掉

EXPLAIN SELECT SQL_NO_CACHE * FROM `test_user` WHERE  lan_id=317 AND region_id=92;

我们使用EXPLAIN关键字看一下

技术图片

 

 因此,我们得出结论:如果建立的是复合索引,索引的顺序要按照建立时的顺序,即从左到右,如:a->b->c(和 B+树的数据结构有关)

无效索引举例

 

优化三:不要对索引做以下处理

我们以!=为例演示,我们使用EXPLAIN关键字看一下

技术图片

 

 

优化四:索引不要放在范围查询右边

比如复合索引:a->b->c,当 where a="" and b>10 and c="",这时候只能用到 a 和 b,c 用不到索引,因为在范围之后索引都失效(和 B+树结构有关)

如下



EXPLAIN SELECT SQL_NO_CACHE * FROM `test_user` WHERE phone=15190427892 AND lan_id>317 AND region_id=92;

我们使用EXPLAIN关键字看一下

技术图片

 

 我们把最后一个条件删除,再看一下

技术图片

 

 

优化五:减少 select * 的使用

select *会查询很多不必要的字段,造成不必要的网络传输和IO消耗

 

优化六:like 模糊搜索

失效情况

技术图片

 

解决方案

技术图片

 

 

技术图片

 

优化七:order by 优化

当查询语句中使用 order by 进行排序时,如果没有使用索引进行排序,会出现 filesort 文件内排序,这种情况在数据量大或者并发高的时候,会有性能问题,需要优化。

filesort 出现的情况举例

如下情况没有索引

技术图片

 

  filesort 文件内排序会在内存开辟一块空间,然后把数据复制了一份放到这个空间内,再进行排序,这个是很影响性能的

我们可以为这个字段建一个索引

ALTER TABLE test_user ADD INDEX idx_create_time(create_time);

技术图片

索引层面解决方法

 

优化八:group by

其原理也是先排序后分组,其优化方式可参考order by。where高于having,能写在where限定的条件就不要去having限定了。

 

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!