网站模板怎么使用,浙江华企做网站,浙江网站改版设计公司,图片编辑软件#xff08;1#xff09;explain之ref介绍
type下的ref是非唯一性索引扫描具体的一个值 ref属性 例如#xff1a;ti表先加载#xff0c;const是常量 t1.other_column是个t1表常量
test.t1.ID#xff1a;test库t1表的ID字段 t1表引用了shared库的t2表的col1字段#x…1explain之ref介绍
type下的ref是非唯一性索引扫描具体的一个值 ref属性 例如ti表先加载const是常量 t1.other_column是个t1表常量
test.t1.IDtest库t1表的ID字段 t1表引用了shared库的t2表的col1字段t1.col2‘’ac‘’是一个常量 t2表没有索引只有id主键col1col2没有建立索引 2explain之rows介绍 rows越少越好 t2开始没有索引t2理论上用到主键索引但是实际上没用到 rows为6401然后加索引后rows变为1421 所以呢我们需要先会看explain优化查询需要先会看 最终优化的效果是把不合适的索引删除逐渐建立索引建立最符合我们系统的这样我们MySql数据库跟我们系统跑起来就是最好的 3explain之Extra介绍 explain中重要的几个字段id type key rows Extra这几个是最重要的 加了\G是竖着排列
第一个sql没有按照创建的索引走我自己在内部产生了一次排序使用了Using filesort文件排序
第二个sql按照创建的索引走性能更加 出现了使用Using temporary比上面Using filesort更影响效率查询更慢
使用了临时表示非常消耗性能的因为你创建搬数据到临时表用完之后再把临时表回收数据库内部要折腾一次
group by正常来讲要不别建立索引要建立索引grooup by一定要和索引的个数和顺序按序来否则非常容易出现文件内排序 建立的索引是一个复合索引没有写select * 你建立的三个字段的复合索引正好你查询的也是这三个字段咱们两个个数和顺序刚好匹配或者部分满足所以这就是覆盖索引 比如你查询join非常多了所以你配置文件的缓冲就可以调大一点