sql:SQL优化知识点记录(四)

(1)explain之ref介绍

type下的ref是非唯一性索引扫描具体的一个值

ref属性

例如:ti表先加载,const是常量 t1.other_column是个t1表常量

test.t1.ID:test库t1表的ID字段

t1表引用了shared库的t2表的col1字段,t1.col2=''ac''是一个常量 t2表没有索引只有id主键,col1,col2没有建立索引

(2)explain之rows介绍

rows越少越好!

t2开始没有索引t2理论上用到主键索引,但是实际上没用到 ,rows为640+1,然后加索引后,rows变为142+1

所以呢,我们需要先会看explain优化查询,需要先会看 ,最终优化的效果是把不合适的索引删除,逐渐建立索引,建立最符合我们系统的,这样我们MySql数据库跟我们系统跑起来就是最好的!

(3)explain之Extra介绍

explain中重要的几个字段:id type key rows Extra这几个是最重要的

加了\G是竖着排列

第一个sql没有按照创建的索引走,我自己在内部产生了一次排序,使用了Using filesort文件排序

第二个sql按照创建的索引走,性能更加

出现了使用Using temporary比上面Using filesort更影响效率,查询更慢

使用了临时表示非常消耗性能的,因为你创建搬数据到临时表,用完之后再把临时表回收,数据库内部要折腾一次

group by正常来讲要不别建立索引,要建立索引,grooup by一定要和索引的个数和顺序按序来,否则非常容易出现文件内排序

建立的索引是一个复合索引,没有写select * ,你建立的三个字段的复合索引,正好你查询的也是这三个字段,咱们两个个数和顺序刚好匹配(或者部分满足),所以这就是覆盖索引

比如你查询join非常多了,所以你配置文件的缓冲就可以调大一点

相关推荐
whn197710 分钟前
Gbase 8A密码有效期剩余天数检查
数据库
煎蛋学姐28 分钟前
SSM速到校园网上订餐网站5n2pv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·用户管理·校园订餐系统·ssm 框架
西岭千秋雪_30 分钟前
MySQL日志梳理(存储引擎层)
java·数据库·分布式·mysql·oracle
老华带你飞1 小时前
英语学习|基于Java英语学习系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·学习
思成不止于此1 小时前
MySQL 查询基础(一):列选择、算数运算与别名使用
数据库·笔记·sql·学习·oracle
蟹至之1 小时前
【MySQL】索引 (下) —— 索引的类型、创建索引、删除索引
数据库·mysql·索引
一 乐1 小时前
校园社区系统|基于java+vue的校园悬赏任务平台系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
bing_1582 小时前
MongoDB中如下参数是什么含义
数据库·mongodb
一过菜只因2 小时前
MySql学习(2)
数据库·学习·mysql
Geoking.3 小时前
Redis 中 ziplist 与 quicklist 解析与对比
数据库·redis·缓存