当前位置: 首页 > 编程笔记 >

Mysql性能优化案例 - 覆盖索引分享

谢奇略
2023-03-14
本文向大家介绍Mysql性能优化案例 - 覆盖索引分享,包括了Mysql性能优化案例 - 覆盖索引分享的使用技巧和注意事项,需要的朋友参考一下

场景

产品中有一张图片表,数据量将近100万条,有一条相关的查询语句,由于执行频次较高,想针对此语句进行优化

表结构很简单,主要字段:


user_id 用户ID

picname 图片名称

smallimg 小图名称

一个用户会有多条图片记录

现在有一个根据user_id建立的索引:uid

查询语句也很简单:取得某用户的图片集合


select picname, smallimg 

from pics where user_id = xxx;

优化前

执行查询语句(为了查看真实执行时间,强制不使用缓存)


select SQL_NO_CACHE picname, smallimg 

from pics where user_id=17853;

执行了10次,平均耗时在40ms左右

使用explain进行分析


explain select SQL_NO_CACHE picname, smallimg 

from pics where user_id=17853

使用了user_id的索引,并且是const常数查找,表示性能已经很好了

优化

因为这个语句太简单,sql本身没有什么优化空间,就考虑了索引

修改索引结构,建立一个(user_id,picname,smallimg)的联合索引:uid_pic

重新执行10次,平均耗时降到了30ms左右

使用explain进行分析

看到使用的索引变成了刚刚建立的联合索引,并且Extra部分显示使用了'Using Index'

总结

'Using Index'的意思是“覆盖索引”,它是使上面sql性能提升的关键

一个包含查询所需字段的索引称为“覆盖索引”

MySQL只需要通过索引就可以返回查询所需要的数据,而不必在查到索引之后进行回表操作,减少IO,提高了效率

例如上面的sql,查询条件是user_id,可以使用联合索引,要查询的字段是picname smallimg,这两个字段也在联合索引中,这就实现了“覆盖索引”,可以根据这个联合索引一次性完成查询工作,所以提升了性能

 类似资料:
  • 本文向大家介绍Mysql性能优化案例研究-覆盖索引和SQL_NO_CACHE,包括了Mysql性能优化案例研究-覆盖索引和SQL_NO_CACHE的使用技巧和注意事项,需要的朋友参考一下 场景 产品中有一张图片表pics,数据量将近100万条,有一条相关的查询语句,由于执行频次较高,想针对此语句进行优化 表结构很简单,主要字段: 一个用户会有多条图片记录,现在有一个根据user_id建立的索引:u

  • 本文向大家介绍mysql性能优化之索引优化,包括了mysql性能优化之索引优化的使用技巧和注意事项,需要的朋友参考一下   作为免费又高效的数据库,mysql基本是首选。良好的安全连接,自带查询解析、sql语句优化,使用读写锁(细化到行)、事物隔离和多版本并发控制提高并发,完备的事务日志记录,强大的存储引擎提供高效查询(表记录可达百万级),如果是InnoDB,还可在崩溃后进行完整的恢复,优点非常多

  • 本文向大家介绍Mysql性能优化方案分享,包括了Mysql性能优化方案分享的使用技巧和注意事项,需要的朋友参考一下 网上有不少mysql 性能优化方案,不过,mysql的优化同sql server相比,更为麻烦,同样的设置,在不同的环境下 ,由于内存,访问量,读写频率,数据差异等等情况,可能会出现不同的结果,因此简单地根据某个给出方案来配置mysql是行不通的,最好能使用status信息对mysq

  • 本文向大家介绍MySQL覆盖索引的使用示例,包括了MySQL覆盖索引的使用示例的使用技巧和注意事项,需要的朋友参考一下 什么是覆盖索引 创建一个索引,该索引包含查询中用到的所有字段,称为“覆盖索引”。 使用覆盖索引,MySQL 只需要通过索引就可以查找和返回查询所需要的数据,而不必在使用索引处理数据之后再进行回表操作。 覆盖索引可以一次性完成查询工作,有效减少IO,提高查询效率。 使用示例 查询语

  • 主要内容:1 独立的列,2 前缀索引和索引选择性,3 多列(组合、联合)索引,3.1 多个单列索引的问题,3.2 使用多列索引,4 选择适合的索引列顺序,5 聚簇(聚集)索引,6 覆盖索引详细介绍了各种高性能的索引使用策略,比如联合索引、索引顺序、聚簇索引、覆盖索引等等,以及常见索引失效的情况。 前面我们已经介绍了各种类型的索引结构及其对应的优缺点: BTREE索引的数据结构以及具体实现原理深入解析 哈希索引的数据结构以及索引的优缺点 正确的创建和使用索引是实现高性能查询的基础。我们通常会看到一

  • 本文向大家介绍浅谈MySQL索引优化分析,包括了浅谈MySQL索引优化分析的使用技巧和注意事项,需要的朋友参考一下 为什么你写的sql查询慢?为什么你建的索引常失效?通过本章内容,你将学会MySQL性能下降的原因,索引的简介,索引创建的原则,explain命令的使用,以及explain输出字段的意义。助你了解索引,分析索引,使用索引,从而写出更高性能的sql语句。还在等啥子?撸起袖子就是干! 案例