sql优化问题笔记(mysql)

相信大家平时面试都会遇到这个问题:平时你都是怎么对sql进行调优的?

此篇文章相当于一个随便笔记,根据朋友们的聊天记录整理而成,如有不对,请指正!

注意:这篇是以mysql整理的

查看sql计划分析

explain sql语句,根据type key extra进行相应优化

type=all代表 mysql本次查询 进行全表扫描了 就是 把整张表的所有数据都扫描了一遍才给你返回的查询结果 由上至下,效率越来越高 index:索引全扫描 range : 索引范围扫描,常用语<,<=,>=,between等操作 ref :使用非唯一索引扫描或唯一索引前缀扫描,返回单条记录,常出现在关联查询中 eq_ref :类似ref,区别在于使用的是唯一索引,使用主键的关联查询 const/system :单条记录,系统会把匹配行中的其他列作为常数处理,如主键或唯一索引查询 null : MySQL不访问任何表或索引,直接返回结果

extra列 extra列: using index:出现这个说明mysql使用了覆盖索引,避免访问了表的数据行,效率不错! using where:这说明服务器在存储引擎收到行后将进行过滤。有些where中的条件会有属于索引的列,当它读取使用索引的时候,就会被过滤,所以会出现有些where语句并没有在extra列中出现using where这么一个说明。 using temporary:这意味着mysql对查询结果进行排序的时候使用了一张临时表。 using filesort:这个说明mysql会对数据使用一个外部的索引排序,而不是按照表内的索引顺序进行读取。

常规检查

  • 不写*
  • 不使用sql函数
  • 表字段不要为null 等等
  • 大数据量的分页 不能使用传统的limit 10,10方式 改成id>xxx 使用索引的方式等
原文地址:https://www.cnblogs.com/zhenghengbin/p/10781611.html