阅读目录(Content)
SQL执行计划的输出可能为多行,每一行代表对一个数据库对象的操作
1. ID列
- ID列中的如果数据为一组数字,表示执行SELECT语句的顺序;如果为NULL,则说明这一行数据是由另外两个SQL语句进行 UNION操作后产生的结果集
- ID值相同时,说明SQL执行顺序是按照显示的从上至下执行的
- ID值不同时,ID值越大代表优先级越高,则越先被执行
演示

可以看到上面的执行计划返回了3行结果,id列的值可以看作是SQL中所具有的SELECT操作的序号
由于上述SQL中只有一个SELECT,所以id全为1,因此,我们就要按照由上至下读取执行计划
按照我们的SQL语句,我们会认为执行顺序是a,b,c,但是通过上图可以发现,Mysql并不是完成按照SQL中所写的顺序来进行表的关联操作的
执行对表的执行顺序为a,c,b,这是由于MySQL优化器会根据表中的索引的统计信息来调整表关联的实际顺序2. SELECT_TYPE列
值 含义 SIMPLE 不包含子查询或是UNION操作的查询 PRIMARY 查询中如果包含任何子查询,那么最外层的查询则被标记为PRIMARY SUBQUERY SELECT 列表中的子查询 DEPENDENT SUBQUERY 依赖外部结果的子查询 UNION Union操作的第二个或是之后的查询的值为union DEPENDENT UNION 当UNION作为子查询时,第二或是第二个后的查询的select_type值 UNION RESULT UNION产生的结果集 DERIVED 出现在FROM子句中的子查询 3. TABLE列
包含以下几种结果:
输出去数据行所在表的名称,如果表取了别名,则显示的是别名 <union M,N>: 由ID为M,N查询union产生的结果集 <derived N>/<subquery N> :由ID为N的查询产生的结果4. PARTITIONS列:
查询匹配的记录来自哪一个分区 对于分区表,显示查询的分区ID 对于非分区表,显示为NULL5. TYPE列
按性能从高至低排列如下:
值 含义 system 这是const联接类型的一个特例,当查询的表只有一行时使用 关键字:青岛软件培训
可能你正在寻找一家靠谱的IT培训机构, 渴望突破职业瓶颈, 找一份得体的工作。 恰巧万码学堂正在寻找像你这样不甘平凡的追光者! 我们拒绝纸上谈兵,直接参与真实开发流程!
申请免费试听课程
现在行动,未来可期
立即拨打0532-85025005,预约免费职业规划咨询 前20名咨询者赠送《2025高薪技术岗位白皮书》!
你不是在报名课程,而是在投资五年后的自己!50000+5万行代码练就真实本领17年创办于2008年老牌培训机构1000+合作企业98%就业率
