MySQL使用问题_mysql的使用

MySQL使用问题_mysql的使用MySQL常见的性能瓶颈一般都是出现在CPU和I/O上,即在数据装入内存中或磁盘上读取数据时,CPU发生了饱和或装入数据过大,内存容量不足,磁盘I/O性能被限制。这时候就要使用到Explain关键字来进行分析和调优。 基本使用 Explain关键字可以用来模拟优化器执行SQL查询语句,从而了解SQL语句的处理方式,来达到分析查询语句或表结构的性能瓶颈。通过Explain可以获得表…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

MySQL常见的性能瓶颈一般都是出现在CPU和I/O上,即在数据装入内存中或磁盘上读取数据时,CPU发生了饱和或装入数据过大,内存容量不足,磁盘I/O性能被限制。这时候就要使用到Explain关键字来进行分析和调优。

  • 基本使用

Explain关键字可以用来模拟优化器执行SQL查询语句,从而了解SQL语句的处理方式,来达到分析查询语句或表结构的性能瓶颈。

通过Explain可以获得

  1. 表的读取顺序和引用
  2. 数据读取操作的基本类型
  3. 可使用的索引以及实际使用的索引
  4. 优化器的查询行数

使用方法:

Explain + SQL语句

MySQL使用问题_mysql的使用

可得到的信息

MySQL使用问题_mysql的使用

  • 参数意义

  • id

表示select查询的序列编号,即在查询中执行select语句或操作表的顺序,查询出来的id有两种情况,可同时存在

id相同,执行顺序为从上到下

MySQL使用问题_mysql的使用

id不同,如果是子查询,id的序列号会递增,id值越大,优先级越高,越早被执行

MySQL使用问题_mysql的使用

  • select_type

查询的类型,主要用于区分普通查询、联合查询、子查询等不同的查询方式,有以下几种

1. SIMPLE:简单的SELECT查询,不包含子查询或UNION

2. PRIMARY:查询中包含子查询等复杂查询时,外层查询则被标记为PRIMARY

3. SUBQUERY:在SELECT或WHERE中包含子查询

4. DERIVED:在FROM中包含了子查询

5. UNION:在关键字UNION后的查询

6. UNION RESULT:从UNION表中获得结果的查询

  • table

表明数据是从那张表中查询的,关联了哪些表

  • partitions

表示查找的是哪个分区的数据​​​​​​​

  • type

​​​​​​​表示查询使用了哪种类型,具体类型有

  1. system:表只有一行记录,等同于系统表,这是const类型的特例,基本不会出现
  2. const:表示通过索引一次就找到了匹配的数据,例如通过主键匹配的条件查询
  3. eq_ref: 唯一性索引扫描,对每个索引键表中只有一条相对应的记录,也就是主键或唯一索引和他们对应的数据这样的情况
  4. ref: 非唯一性索引扫描,即索引查找出对应多个符合条件的数据
  5. range: 只检索给定范围的行,使用一个索引来选择行,一般是between、<、>、in等范围查询
  6. index: 从索引中读取全表
  7. all:从硬盘中读取全表,即全数据读取

查询效率:从优到劣顺序排列

  • possible_keys

​​​​​​​表示可能使用到的索引,通常如果查询的字段上有索引就会显示,虽然不一定会使用到

  • key

​​​​​​​实际使用到的索引,如果在查询中使用到了覆盖索引,则该索引会和查询的select字段重叠

  • key_len

​​​​​​​索引的长度,越短越好,该值为表计算估计出的最大长度,而不是实际使用长度

  • ref

​​​​​​​显示索引的哪一列被使用到了

  • rows

​​​​​​​预计找出匹配数据所需要读取的行数

  • Extra

​​​​​​​额外的事务,是比较重要的用于分析检索效率的信息,包含以下:

  1. Using filesort:MySQL使用了一个外部的索引排序:“文件排序”,表示无法使用表内的索引顺序进行读取
  2. Using temporary:使用了临时表,该信息通常在使用了排序或分组查询时出现,MySQL使用了临时表来存储order by和group by需要进行排序的查询结果
  3. Using index:在select操作中使用了覆盖索引,即只从索引中就可以获得数据,不必读取数据行。覆盖索引:是建立在原有索引基础上的新的索引。
  4. Using where:使用了where过滤,当同时出现Using index时,表示索引被用于读取索引键值的操作,索引键即为where的过滤条件
  5. using join buffer:使用了连接缓存
  6. impossible where:where子句的值为false,不能被用于查找数据
  7. select tables optimized away:表示索引在没有group by的情况下,在查询阶段就优化了cont(*)等函数操作
  8. distinct:优化了distinct操作,匹配到第一组所需的数据后停止查找相同数据的操作

MySQL使用问题_mysql的使用

扫码关注我的微信公众号:Java架构师进阶编程  获取最新面试题,电子书

专注分享Java技术干货,包括JVM、SpringBoot、SpringCloud、数据库、架构设计、面试题、电子书等,期待你的关注!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180825.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月17日 下午10:46
下一篇 2022年10月17日 下午10:46


相关推荐

  • 实战教程!告别昂贵的 Claude,开箱即用,OpenClaw中文版Agent平台,原生支持DeepSeek、Qwen 国产大模型

    实战教程!告别昂贵的 Claude,开箱即用,OpenClaw中文版Agent平台,原生支持DeepSeek、Qwen 国产大模型

    2026年3月13日
    2
  • hadoop使用教程_hadoop入门

    hadoop使用教程_hadoop入门Hadoop【大数据Hadoop系列】Hadoop2.X单机环境搭建【大数据Hadoop系列】Hadoop2.X集群环境搭建MapReduce【大数据Hadoop系列】分布式计算框架——MapReduceYARN【大数据Hadoop系列】Hadoop-YARN知识体系总结(2021版)【大数据Hadoop系列】集群资源管理器——YARNHDFS【大数据Hadoop系列】Hadoop-HDFS知识体系总结(2021版)【大数据Hadoop系列】Hadoop分

    2025年6月3日
    2
  • js 实现纯前端将数据导出excel两种方式,亲测有效「建议收藏」

    由于项目需要,需要在不调用后台接口的情况下,将json数据导出到excel表格,参考了好多资料以及很多大佬写的博客终于实现,兼容chrome没问题,其他还没有测试过,这边介绍两种实现方式,并附上代码和gif动图,博主不才还望轻喷

    2022年4月17日
    60
  • harmonyos系统与安卓区别(uAndroid)

    目录一、前言二、HarmonyOS与Android的对比2.1HarmonyOS并不是Android的替代品2.2系统定位2.3内核对比2.4运行速度三、方舟编译器一、前言这段时间我在寻思这学习一下鸿蒙,第一是因为在着手做一个自己的开源项目,技术选型的时候想到了鸿蒙;第二是我个人非常看好鸿蒙系统的未来,清除明白华为和一些民族企业担负的责任和国人的期待,虽然带着一些民族感情;鸿蒙刚发布的时候自己是非常激动的,但是后来项目太忙一直没有认真的去了解过,这次打算花一部

    2022年4月13日
    161
  • 使用 qrcodejs2 生成二维码详细API和参数

    使用 qrcodejs2 生成二维码详细API和参数使用 qrcodejs2 页面引入页面标签可以使 id 或者 ref 建议使 ref 因为使 vue 框架控制虚拟 Dom 才是正确的选择简单 便参数说明 OptionsEvent

    2026年3月17日
    2
  • webgame开发中配置存储的介绍「建议收藏」

    webgame开发中配置存储的介绍「建议收藏」webgame世界的基础数值都是事先配置好的,在运行的时候可以随时读取,是属于非常重要和必不可少的部分,而且数据量也不少。这样的数据在开发中的存储也就变得重要了,需要保证效率、性能、安全等,一般的做法有使用xml文本文件保存、静态数组保存和数据库直接保存。 xml文本文件保存优点: 共享性强,几乎每种语言都可以读取和解析xml文件,方便多语言混合开发。 结构清晰,xml的结构很

    2022年5月2日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号