Java学习 - MySQL常用性能优化 + Explain查看执行计划

常用性能优化方式

  • 服务器硬件优化:加机器,加内存
  • MySQL服务器优化:更改参数,增加缓冲等等
  • SQL本身优化:减少子查询,减少连接查询的使用
  • 反范式设计优化:为了减少连接查询使用,可以允许适量数据冗余,使用空间换时间
  • 物理设计优化:
    • 选择更好的数据类型:数值 > 时间日期 > 字符类型;同级别数据类型,优先选择占用空间少的数据类型
    • 选择合适的存储引擎:MyiSAM和Memory的性能都比InnoDB要好
  • 添加索引优化

SQL执行加载顺序

  • 人写
mysql 复制代码
SELECT
FROM
JOIN ON
WHERE
GROUP BY
HAVING
ORDER BY
LIMIT
  • 机读
mysql 复制代码
FROM
JOIN ON
WHERE
GROUP BY
HAVING
SELECT
ORDER BY
LIMIT

Explain查看执行计划

Explain是什么
  • Explain是MySQL自带的查看SQL执行计划工具,能够知道MySQL是怎样处理SQL语句的
Explain使用
  • 语法

    mysql 复制代码
    explain SQL语句
  • 例子

    mysql 复制代码
    explain SELECT * FROM user;
Explain结果分析
字段 说明
id id相同为一组,从上往下执行;id越大组的优先级越高
select_type 查询的类型; SIMPLE:简单查询, PRIMARY:子查询中最外层查询, SUBQUERY:子查询中内层查询, DERIVED:产生的临时表, UNION:联合查询, UNION RESULT:联合查询的结果集
table 数据来源的表
type 访问类型; 性能为:system > const > eq_ref > ref > range(至少) > index > ALL
possible_keys SQL执行过程中可能使用到的索引
key SQL执行过程中实际使用到的索引
key_len SQL执行过程中实际使用到的索引占用的字节数 它是计算出来的,并非实际使用长度
ref 显示索引中哪一列被使用了
rows SQL执行过程中实际读取的行数
Extra 包含十分重要,但不方便在表格中显示的内容 Using filesort Using temporary Using index Using where Using join buffer impossible where select tables optimized away distinct
相关推荐
QD_IT伟2 分钟前
SpringBoot项目整合Tlog 数据链路的规范加强
java·spring boot·后端
源码获取_wx:Fegn08952 分钟前
基于springboot + vue二手交易管理系统
java·vue.js·spring boot·后端·spring·课程设计
Zsh-cs3 分钟前
Spring
java·数据库·spring
爬山算法5 分钟前
Springboot请求和响应相关注解及使用场景
java·spring boot·后端
程序员水自流8 分钟前
MySQL InnoDB存储引擎详细介绍之事务
java·数据库·mysql·oracle
Knight_AL10 分钟前
MySQL STORED 生成列(Generated Column)详解:让 SQL 变快的秘密武器
数据库·sql·mysql
请为小H留灯19 分钟前
Java实际开发@常用注解(附实战场景)
java·后端·个人开发
老华带你飞21 分钟前
在线教育|基于springboot + vue在线教育系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
路边草随风22 分钟前
java操作cosn使用
java·大数据·hadoop
TT哇29 分钟前
【项目】玄策五子——匹配模块
java·spring boot·websocket·spring·java-ee·maven