Mysql的索引详解

1.索引的分类

1.按照功能来分,可以分为主键索引、唯一索引、普通索引、全文索引

2.按照索引字段个数来分,可以分为单列索引、联合索引

3.按照物理实现方式来分,可以聚簇索引、非聚簇索引

2.适合添加索引的场景

1.具有唯一性约束的字段。

2.频繁地作为where查询条件的字段,包括select/update/delete。

3.需要gruop by 或 order by的字段

4.distinct字段需要添加索引(实测在数据量小的情况下意义不大)

5.多表连接join时需要注意的事项:连接表的张数最好不要超过3张,对where条件的字段增加索引,对于两表之间的关联字段,被关联表的该字段需要有索引且字段在两表中的属性保持一致。

6.区分度高的字段适合作为索引,反之则不适合。举例:性别字段就两种类型,这种区分度就很低,不适合作为索引。我们常用的xxId,一般来说这种id都是唯一的,每个人的id都不一样,这种区分度就是100%,非常适合作为索引。

3.慢sql分析

可以开启慢sql日志,然后分析慢sql日志中的慢sql。

在my.cnf中开启慢sql日志:

long_query_time=1; //设置慢查询的标准是1S,超过1S就是慢查询。

slow_query_log=ON; //设置开启慢查询日志记录

4.profile分析

对于慢查询sql,可以使用profile工具进行分析,确定SQL主要耗时是在什么步骤。

show profiles; //查询最近的一些sql

show profile for query 704; //展示我们需要查询的sql的详细耗时情况

可以看到上述sql耗时主要在executing步骤,也就是执行阶段。这种时候就需要explain一下sql,查看具体的执行计划进行分析。

5.explain分析

可以看到上述sql走了name索引,Using index表示是走了覆盖索引,但是还是耗时很长,最主要的原因就是扫描的行太多了,也就是rows字段,多达9307475行,就是数据量太大导致的耗时长。

5.1 explain关键字分析

相关推荐
Freedom℡1 分钟前
Spark,SparkSQL操作Mysql, 创建数据库和表
数据库·spark
羊羊羊i27 分钟前
Redis进阶知识
数据库·redis·缓存
枷锁—sha30 分钟前
SQL注入——Sqlmap工具使用
数据库·sql·安全·web安全
进击的CJR2 小时前
MySQL 8.0 OCP 英文题库解析(五)
数据库·mysql·开闭原则
付出不多4 小时前
linux——mysql高可用
linux·运维·mysql
观无5 小时前
数据库DDL
数据库·oracle
消失在人海中5 小时前
Oracle 内存优化
数据库·oracle
昭阳~6 小时前
MySQL读写分离
数据库·mysql
jjkkzzzz8 小时前
Linux下的c/c++开发之操作Redis数据库
数据库·c++·redis
老华带你飞9 小时前
实习记录小程序|基于SSM+Vue的实习记录小程序设计与实现(源码+数据库+文档)
java·数据库·spring boot·小程序·论文·毕设·实习记录小程序