高龄白菜java学习第112天(MySql数据库高级(3))

(4)type:重点

从最好到最差依次是:
system>const>eq_ref>ref>range>index>all

在这里插入图片描述
在这里插入图片描述
eq_ref:双表:前一个表的唯一索引只能在后表中找到唯一记录

(5)key、possible_keys(可以用来做索引失效的校验)

查询的字段就在索引中(顺序和个数都匹配),此时展示的情况就是possible_keys为空但key中有值
(6)key_len:
在这里插入图片描述
key_len只计算where条件用到的索引长度,单列索引计算整个索引长度,多列索引用多少算多少
(7)ref

格式:库.表.字段 const
在这里插入图片描述
(8)rows

在这里插入图片描述
(9)extra 额外内容
在这里插入图片描述
在这里插入图片描述
Using filesort说明:最左原则,中间如果断了就不走索引了

前3个是extra中最重要的指标
在这里插入图片描述

三、索引优化

单表分析

范围之后的索引会失效
在这里插入图片描述
结论:跳过范围比较的字段来创建索引

在这里插入图片描述

两表分析

问题:加在左表还是右表,主键还是外键
分析:
第一种情况:左连接把索引加在了右表上
在这里插入图片描述
第二种情况:左连接把索引加在了左表上

在这里插入图片描述

结论:左右连接索引相反加(加在从表上效率高)

(对应:可以尝试更换sql语句中的主从表位置)

三表分析

在这里插入图片描述

在这里插入图片描述
结论:索引最好设置在需要经常查询的字段上

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值