位置: 编程技术 - 正文

explain分析sql效率的方法

编辑:rootadmin

推荐整理分享explain分析sql效率的方法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决,Explain可以用来查看SQL语句的执行效 果,可以帮助选择更好的索引和优化查询语句,写出更好的优化语句。

Explain语法:

EXPLAIN tbl_name或:EXPLAIN [EXTENDED] SELECT select_options

前者可以得出一个表的字段结构等等,后者主要是给出相关的一些索引信息,而今天要讲述的重点是后者。

例:

执行结果:

下面对各个属性进行了解:

1、id:这是SELECT的查询序列号

2、select_type:select_type就是select的类型,可以有以下几种:

SIMPLE:简单SELECT(不使用UNION或子查询等)

PRIMARY:最外面的SELECT

UNION:UNION中的第二个或后面的SELECT语句

DEPENDENT UNION:UNION中的第二个或后面的SELECT语句,取决于外面的查询

UNION RESULT:UNION的结果。

SUBQUERY:子查询中的第一个SELECT

DEPENDENT SUBQUERY:子查询中的第一个SELECT,取决于外面的查询

DERIVED:导出表的SELECT(FROM子句的子查询)

3、table:显示这一行的数据是关于哪张表的实际的表名(如select * from customer;) 或表的别名 (如 select * from customer a);

4、type:这列最重要,显示了连接使用了哪种类别,有无使用索引,是使用Explain命令分析性能瓶颈的关键项之一。

结果值从好到坏依次是:

system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL

一般来说,得保证查询至少达到range级别,最好能达到ref,否则就可能会出现性能问题。

all: 意味着从表的第1行,往后,逐行做全表扫描.,运气不好扫描到最后一行.

index: 比all性能稍好一点,通俗的说: all 扫描所有的数据行,相当于data_all index 扫描所有的索引节点,相当于index_all

explain分析sql效率的方法

注:all是沿着磁盘扫描,index是沿着索引扫描

range: 意思是查询时,能根据索引做范围的扫描

explain select * from customer where customer_id > 4;

index_subquery 在子查询中,基于除唯一索引之外的索引进行扫描;

unique_subquery 在子查询中,基于唯一索引进行扫描,类似于EQ_REF;

index_merge 多重范围扫描。两表连接的每个表的连接字段上均有索引存在且索引有序,结果合并在一起。适用于作集合的并、交操作。

ref_or_null 类似REF,只是搜索条件包括:连接字段的值可以为NULL的情况,比如 where col = 2 or col is null

fulltext 全文索引

ref 这也是一种索引访问,它返回所有匹配某个单独值的行,然而,它可能会找到多个符合条件的行,所以他应该属于查找和扫描的混合体(也是范围区间,不过比range更加精确)。

explain select * from payment where customer_id =4;

eq_ref 是指,通过索引列,直接引用某1行数据(精确到一行数据中)常见于连接查询中

const, system, null 当mysql能对查询的部分就行优化,并且转换成一个常量的时候,它就会使用这种访问类型了。比如你把一行的主键当做where条件放进去,那mysql就可以把它转换成一个常量,然后查询.

5、possible_keys:列指出MySQL能使用哪个索引在该表中找到行

6、key:显示MySQL实际决定使用的键(索引)。如果没有选择索引,键是NULL

7、key_len:显示MySQL决定使用的键长度。如果键是NULL,则长度为NULL。使用的索引的长度。在不损失精确性的情况下,长度越短越好

8、ref:显示使用哪个列或常数与key一起从表中选择行。

9、rows:显示MySQL认为它执行查询时必须检查的行数。

、Extra:包含MySQL解决查询的详细信息,也是关键参考项之一。

除此以外,explain 的extended 扩展能够在原本explain的基础上额外的提供一些查询优化的信息,这些信息可以通过mysql的show warnings命令得到。下面是一个最简单的例子。 

接下来再执行Show Warnings  

可以看到优化器自动去除了1=1恒成立的条件。 

MySQL5.1开始支持分区功能,同时explain命令也增加了对分区的支持。可以通过explain partitions 命令查看SQL所访问的分区。

以上这篇explain分析sql效率的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

MySQL中Decimal类型和Float Double的区别(详解) MySQL中存在float,double等非标准数据类型,也有decimal这种标准数据类型。其区别在于,float,double等非标准类型,在DB中保存的是近似值,而Decimal则以字符

浅谈mysql的索引设计原则以及常见索引的区别 索引定义:是一个单独的,存储在磁盘上的数据库结构,其包含着对数据表里所有记录的引用指针.数据库索引的设计原则:为了使索引的使用效率更高

MySQL5绿色版windows下安装总结(推荐) 1下载MySQL下载地址:

标签: explain分析sql效率的方法

本文链接地址:https://www.jiuchutong.com/biancheng/349988.html 转载请保留说明!

上一篇:重置MySQL中表中自增列的初始值的实现方法(mysql重置初始密码)

下一篇:mysql去重的两种方法详解及实例代码(mysql中的去重)

  • 劳务派遣公司差额征税的账务处理
  • 课税为什么叫课税
  • 国家重大水利工程建设基金计算方法
  • 偷税漏税逃税是什么意思
  • 企业异地迁移
  • 银行收取的账户管理费是什么费用
  • 离职员工个税申报时员工状态依然是雇员
  • 水利建设基金一定要交吗
  • 企业所得税申报表在哪里打印
  • 汇总记账凭证长什么样
  • 国有企业业务招待费管理办法
  • 用党委经费买的固定资产如何计提?
  • 公司购入的房子如何抵押
  • 扩建费用
  • 房产报废手续
  • 土地平整费计入什么科目
  • 财务分析的起点是企业的内部分析报告
  • 企业从境外收回所得税
  • 员工给公司代垫的款项分录
  • 企业自然人电子税务局怎么申报
  • win10系统声音有杂音
  • 农业合作社零申报流程
  • 非房地产企业的基建管理办法
  • 快递公司账务处理流程及方法
  • 金蝶系统怎么修改库存数量
  • PHP:xml_parser_free()的用法_XML解析器函数
  • win11 zen2
  • 餐费发票可以抵扣成本吗
  • 怎么获取免费的腾讯vip
  • 调整系统保留带宽的命令
  • 收益性支出与资本性支出的主要特点
  • bigfile是什么意思
  • 法国著名画家塞尚属于什么流派?
  • oeloader.exe - oeloader是什么进程 有什么用
  • 禁止input标签输入
  • php5.4升级到php7
  • PHP:is_writeable()的用法_Filesystem函数
  • 发包工程补付工程款分录
  • 某建筑公司因施工期紧迫,事先未能与有关
  • 停产企业税收申请减免
  • 资产负债表应付账款怎么填列
  • 银行贷款用途能改吗
  • 怎么用云服务
  • nginx连接超时时间设置多少
  • thinkphp yii
  • 购入固定资产的会计处理
  • 石油预付款发票怎么开
  • 怎样计算负债率
  • 帝国cms破解授权
  • 资产处置收益的账务处理
  • mongodb从入门到商业实战
  • 土地租赁费计入哪个科目
  • 工会会计需要会计证吗
  • 使用mysql的disctinct group by查询不重复记录
  • 劳务外经证预缴税款
  • 建筑工程机械设备租赁属于什么行业
  • 以前年度多交的房产税现在收到退税款了咋做分录
  • 跨年发票如何做会计分录
  • 个人新冠肺炎确诊,要和单位领导说吗
  • 研究费用记入什么费用
  • 价外费用延期付款利息
  • 公司办公室买的茶叶怎么入账
  • 企业注销在建工程怎么处理
  • 车间不生产折旧计提放哪里
  • 价税合计怎么求税额
  • 进项税额转出还要交税吗
  • 咨询费开发票应该选哪一项?
  • 营业外支出为负数原因
  • sql server错误和使用情况报告
  • mysql正则表达式匹配数字
  • xp系统打开注册表
  • 使用dhcp的好处有哪些
  • xp停在windows界面
  • imac 迅雷
  • win7系统电脑硬盘图标变了,控制面板也打不开
  • win10浏览器没有网络连接
  • windows8.1控制面板
  • 曲靖市税务局领导班子
  • 社保批扣和灵活就业批扣有什么区别
  • 二手车中介公司怎么做账报税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设