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
相关推荐
对 酒 当 歌 人 生 几 何几秒前
Mysql多表连接
数据库·sql·mysql
IT教程资源C3 分钟前
(N_128)基于springboot,vue酒店管理系统
mysql·vue·前后端分离·酒店管理系统·springboot酒店
s***11703 分钟前
使用rustDesk搭建私有远程桌面
java
编程修仙10 分钟前
第九篇 Spring中的代理思想
java·后端·spring
杀死那个蝈坦12 分钟前
MyBatis-Plus 使用指南
java·kafka·tomcat·mybatis—plus
I'm Jie22 分钟前
告别重复编码!SpringBoot 字段变更(新旧值)日志工具类的规范化设计与优雅实现
java·spring boot·后端
找了一圈尾巴25 分钟前
LLM-as-a-Judge-论文学习(中)
学习·模型评估
哥谭居民000128 分钟前
需求分析,领域划分到选择套用业务模式到转化落地,两个基本案例
java·大数据·需求分析
Ttang2332 分钟前
【AI学习1】了解开源大模型
人工智能·学习·开源
Tao____33 分钟前
适合中小型项目的物联网平台
java·物联网·mqtt·开源·iot