百摩网
当前位置: 首页 生活百科

mysql执行计划顺序(mysql执行计划)

时间:2023-07-25 作者: 小编 阅读量: 3 栏目名: 生活百科

接下来我们就一起去了解一下吧!mysql执行计划顺序在企业的应用场景中,为了知道优化SQL语句的执行,需要查看SQL语句的具体执行过程,以加快SQL语句的执行效率。可以使用explainSQL语句来模拟优化器执行SQL查询语句,从而知道mysql是如何处理sql语句的。

mysql执行计划顺序?在企业的应用场景中,为了知道优化SQL语句的执行,需要查看SQL语句的具体执行过程,以加快SQL语句的执行效率,下面我们就来聊聊关于mysql执行计划顺序?接下来我们就一起去了解一下吧!

mysql执行计划顺序

在企业的应用场景中,为了知道优化SQL语句的执行,需要查看SQL语句的具体执行过程,以加快SQL语句的执行效率。

可以使用explain SQL语句来模拟优化器执行SQL查询语句,从而知道mysql是如何处理sql语句的。

官网地址: https://dev.mysql.com/doc/refman/5.5/en/explain-output.html

1、执行计划中包含的信息

Column

Meaning

id

The SELECT identifier

select_type

The SELECT type

table

The table for the output row

partitions

The matching partitions

type

The join type

possible_keys

The possible indexes to choose

key

The index actually chosen

key_len

The length of the chosen key

ref

The columns compared to the index

rows

Estimate of rows to be examined

filtered

Percentage of rows filtered by table condition

extra

Additional information

id

select查询的序列号,包含一组数字,表示查询中执行select子句或者操作表的顺序

id号分为三种情况:

1、如果id相同,那么执行顺序从上到下

explain select * from emp e join dept d on e.deptno = d.deptno join salgrade sg on e.sal between sg.losal and sg.hisal;

2、如果id不同,如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行

explain select * from emp e where e.deptno in (select d.deptno from dept d where d.dname = 'SALES');

3、id相同和不同的,同时存在:相同的可以认为是一组,从上往下顺序执行,在所有组中,id值越大,优先级越高,越先执行

explain select * from emp e join dept d on e.deptno = d.deptno join salgrade sg on e.sal between sg.losal and sg.hisal where e.deptno in (select d.deptno from dept d where d.dname = 'SALES');

select_type

主要用来分辨查询的类型,是普通查询还是联合查询还是子查询

select_type Value

Meaning

SIMPLE

Simple SELECT (not using UNION or subqueries)

PRIMARY

Outermost SELECT

UNION

Second or later SELECT statement in a UNION

DEPENDENT UNION

Second or later SELECT statement in a UNION, dependent on outer query

UNION RESULT

Result of a UNION.

SUBQUERY

First SELECT in subquery

DEPENDENT SUBQUERY

First SELECT in subquery, dependent on outer query

DERIVED

Derived table

UNCACHEABLE SUBQUERY

A subquery for which the result cannot be cached and must be re-evaluated for each row of the outer query

UNCACHEABLE UNION

The second or later select in a UNION that belongs to an uncacheable subquery (see UNCACHEABLE SUBQUERY)

--sample:简单的查询,不包含子查询和union

explain select * from emp;

--primary:查询中若包含任何复杂的子查询,最外层查询则被标记为Primary

explain select staname,ename supname from (select ename staname,mgr from emp) t join emp on t.mgr=emp.empno ;

--union:若第二个select出现在union之后,则被标记为union

explain select * from emp where deptno = 10 union select * from emp where sal >2000;

--dependent union:跟union类似,此处的depentent表示union或union all联合而成的结果会受外部表影响

explain select * from emp e where e.empno in ( select empno from emp where deptno = 10 union select empno from emp where sal >2000)

--union result:从union表获取结果的select

explain select * from emp where deptno = 10 union select * from emp where sal >2000;

--subquery:在select或者where列表中包含子查询

explain select * from emp where sal > (select avg(sal) from emp) ;

--dependent subquery:subquery的子查询要受到外部表查询的影响

explain select * from emp e where e.deptno in (select distinct deptno from dept);

--DERIVED: from子句中出现的子查询,也叫做派生类,

explain select staname,ename supname from (select ename staname,mgr from emp) t join emp on t.mgr=emp.empno ;

--UNCACHEABLE SUBQUERY:表示使用子查询的结果不能被缓存

explain select * from emp where empno = (select empno from emp where deptno=@@sort_buffer_size);

--uncacheable union:表示union的查询结果不能被缓存:sql语句未验证

table

对应行正在访问哪一个表,表名或者别名,可能是临时表或者union合并结果集 1、如果是具体的表名,则表明从实际的物理表中获取数据,当然也可以是表的别名

2、表名是derivedN的形式,表示使用了id为N的查询产生的衍生表

3、当有union result的时候,表名是union n1,n2等的形式,n1,n2表示参与union的id

type

type显示的是访问类型,访问类型表示我是以何种方式去访问我们的数据,最容易想的是全表扫描,直接暴力的遍历一张表去寻找需要的数据,效率非常低下,访问的类型有很多,效率从最好到最坏依次是:

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

一般情况下,得保证查询至少达到range级别,最好能达到ref

--all:全表扫描,一般情况下出现这样的sql语句而且数据量比较大的话那么就需要进行优化。

explain select * from emp;

--index:全索引扫描这个比all的效率要好,主要有两种情况,一种是当前的查询时覆盖索引,即我们需要的数据在索引中就可以索取,或者是使用了索引进行排序,这样就避免数据的重排序

explain select empno from emp;

--range:表示利用索引查询的时候限制了范围,在指定范围内进行查询,这样避免了index的全索引扫描,适用的操作符: =, <>, >, >=, <, <=, IS NULL, BETWEEN, LIKE, or IN()

explain select * from emp where empno between 7000 and 7500;

--index_subquery:利用索引来关联子查询,不再扫描全表

explain select * from emp where emp.job in (select job from t_job);

--unique_subquery:该连接类型类似与index_subquery,使用的是唯一索引

explain select * from emp e where e.deptno in (select distinct deptno from dept);

--index_merge:在查询过程中需要多个索引组合使用,没有模拟出来

--ref_or_null:对于某个字段即需要关联条件,也需要null值的情况下,查询优化器会选择这种访问方式

explain select * from emp e where e.mgr is null or e.mgr=7369;

--ref:使用了非唯一性索引进行数据的查找

create index idx_3 on emp(deptno);

explain select * from emp e,dept d where e.deptno =d.deptno;

--eq_ref :使用唯一性索引进行数据查找

explain select * from emp,emp2 where emp.empno = emp2.empno;

--const:这个表至多有一个匹配行,

explain select * from emp where empno = 7369;

--system:表只有一行记录(等于系统表),这是const类型的特例,平时不会出现

possible_keys

显示可能应用在这张表中的索引,一个或多个,查询涉及到的字段上若存在索引,则该索引将被列出,但不一定被查询实际使用

explain select * from emp,dept where emp.deptno = dept.deptno and emp.deptno = 10;

key

实际使用的索引,如果为null,则没有使用索引,查询中若使用了覆盖索引,则该索引和查询的select字段重叠。

explain select * from emp,dept where emp.deptno = dept.deptno and emp.deptno = 10;

key_len

表示索引中使用的字节数,可以通过key_len计算查询中使用的索引长度,在不损失精度的情况下长度越短越好。

explain select * from emp,dept where emp.deptno = dept.deptno and emp.deptno = 10;

ref

显示索引的哪一列被使用了,如果可能的话,是一个常数

explain select * from emp,dept where emp.deptno = dept.deptno and emp.deptno = 10;

rows

根据表的统计信息及索引使用情况,大致估算出找出所需记录需要读取的行数,此参数很重要,直接反应的sql找了多少数据,在完成目的的情况下越少越好

explain select * from emp;

extra

包含额外的信息。

--using filesort:说明mysql无法利用索引进行排序,只能利用排序算法进行排序,会消耗额外的位置

explain select * from emp order by sal;

--using temporary:建立临时表来保存中间结果,查询完成之后把临时表删除

explain select ename,count(*) from emp where deptno = 10 group by ename;

--using index:这个表示当前的查询时覆盖索引的,直接从索引中读取数据,而不用访问数据表。如果同时出现using where 表名索引被用来执行索引键值的查找,如果没有,表面索引被用来读取数据,而不是真的查找

explain select deptno,count(*) from emp group by deptno limit 10;

--using where:使用where进行条件过滤

explain select * from t_user where id = 1;

--using join buffer:使用连接缓存,情况没有模拟出来

--impossible where:where语句的结果总是false

explain select * from emp where empno = 7469;

    推荐阅读
  • 五常市红色主题团建策划(首家沉浸式红色主题剧本杀)

    首家沉浸式红色主题剧本杀想要公司团建既深刻又有趣?大型实景剧本杀✊红色主题带你重走革命路!✔20-600人沉浸式感受紧张氛围!.【活动亮点】①超大场景沉浸式剧本杀体验✨真实还原革命时期地理场景沉浸感满满内容根据真实故事改编自。

  • 化粪池排气孔怎么留置(化粪池排气孔留置方法简述)

    化粪池排气孔留置位置:无覆土在第一池,管径100,上罩管罩另外在化粪池上部圈梁下留孔洞让一二三池气体相通有覆土的话,用钻了孔的100管联通一二三池的气体,在二三池井筒之间接通气管,下面我们就来说一说关于化粪池排气孔怎么留置?有覆土的话,用钻了孔的100管联通一二三池的气体,在二三池井筒之间接通气管。需要留排气口,避免池内沼气积累,发生爆炸。但是可以使积泥在厌氧条件下分解为稳定状态,熟化后用作农业肥料。

  • 累字开头的成语(累字开头的成语有哪些)

    累字开头的成语累卵之危,拼音为wēirúlěiluǎn,比喻形势非常危险,如同堆起来的蛋,随时都有塌下打碎的可能。累教不改,拼音是lěijiàobùgǎi,意思是经过多次教育仍然不改正。累及无辜,拼音是lěijíwúgū,意思是使受牵连;连累到没有罪过的人。累牍连篇,拼音是lěidúliánpiān,意思是指用过多的篇幅叙述。出自唐代魏征《隋书·李谔传》:连篇累牍,不出月露之形。

  • 根号10未来估值(根号叁完成数百万元天使轮融资)

    根号叁完成数百万元天使轮融资创业邦获悉,根号叁(厦门)网络科技有限公司,正式宣布已经完成数百万人民币的天使轮融资,据悉,本轮投资方为乾道基金根号叁成立于2014年,致力于打造全真互联网时代的商业元宇宙平台(BussinessMe。

  • 各种斋号名(名人斋号考下)

    名人斋号考下斋号既反映主人的个性与品味,又关联主人的寄情与爱好治学大家的斋号往往也是后人识别其本人的别称寥寥几字,意义深远除了斋、堂之外,还有如洞、舍、庐、亭、庵、簃、庋、牖、廛、榭、园、岩、巢、村、蓬、窝此次辑。

  • 韩愈简介及事迹(韩愈一介书生手无缚鸡之力)

    韩愈向裴度提出建议,此时派精兵1000人,突袭淮西重要城市蔡州,可一击而成。雪夜入蔡州蔡州成功拿下后,接下来要打镇州。裴度正想调度军队,韩愈阻止了他。公元822年2月,55岁的韩愈手捧圣旨,来到了杀人魔王王庭凑的中军帐。宣完旨,王庭凑与韩愈聊了起来,才知面前这位是大名鼎鼎的韩愈,立即表示从今以后归顺朝廷,服从号令。文起八代之衰,而道济天下之溺,忠犯人主之怒,而勇夺三军之帅。

  • 网线顺序(网线是什么)

    T568A的接线顺序为:白绿、绿、白橙、蓝、白蓝、橙、白棕、橙棕。常用的网线有双绞线和同轴细缆。使用同轴细缆进行网络连接比较简单,只要将每台计算机或网络设备串联起来就可以了,但是维护起来比较麻烦,如果某处出了故障,整个网络就有可能瘫痪。从网络中添加或者去掉一台计算机,就必须停止网络的工作,等到添加或去掉计算机后,才能继续使用。同时,这种方式必须采用总线型拓扑结构,这种结构现在很少使用。

  • 不负韶华上一句是什么(不负韶华作者是谁)

    下面希望有你要的答案,我们一起来看看吧!不负韶华上一句是什么以梦为马以汗为泉不忘初心不负韶华。出自《以梦为马》,是当代诗人海子的著名诗篇。以马这种强健美好的动物作为希望的载体,承载内心的理念和梦想,为未来的人生提供内在支持。

  • 固定门和墙的东西叫什么 门与墙连接的东西叫什么

    固定门和墙的东西叫门吸。门吸也俗称门碰,也是一种门页打开后吸住定位的装置,以防止风吹或碰触门页而关闭。门吸分为永磁门吸和电磁门吸二种,永磁门吸一般用在普通门中,只能手动控制;电磁门吸用在防火门等电控门窗设备,兼有手动控制和自动控制功能。

  • 足球中到底什么叫越位?(正确答案在这里)

    同时比球距离球门更近,并试图借此位置干扰对方球员争球,干扰比赛,接门柱横梁及对方身上反弹球就会被判罚越位。另外需要注意的是,角球和界外球,球门球并不算越位。如果球员站在皮球的前方,或者换句话说就在皮球和对方球门之间,就会被认为是“逾越了他的位置”。这也不是一种一开始就被广泛采纳的规则,谢菲尔德足球俱乐部的原始规则里并没有越位,被称为“直射员”的球员总是站在靠近对方球门的位置。