基于案例理解MySQL执行计划

栏目: 数据库 · 发布时间: 6年前

内容简介:版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/84569447

版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/84569447

一、执行计划一些参考链接

二、获取 SQL 执行计划

方法1(命令行):EXPLAIN sql_statement

方法2(Toad):Toad里边在SQL编辑器里边点击explain plan

方法3(Navicate)Navicate里边点击解释

三、案例

1、原始SQL及完整执行计划

原始SQL语句:
SELECT c.customerNumber, c.customerName, e.lastname
FROM customers c
     INNER JOIN employees e ON c.salesRepEmployeeNumber = e.employeeNumber
WHERE e.lastname LIKE 'T%'
      AND EXISTS
             (SELECT orderNumber, SUM(priceEach * quantityOrdered)
              FROM orderdetails INNER JOIN orders USING (orderNumber)
              WHERE customerNumber = c.customerNumber
              GROUP BY orderNumber
              HAVING SUM(priceEach * quantityOrdered) > 50000)
UNION
SELECT customerNumber, customerName, 'NULL'
FROM customers
WHERE customerName LIKE 'T%'

执行计划截图

基于案例理解 <a href='https://www.codercto.com/topics/18746.html'>MySQL</a> 执行计划

2、执行计划包含的信息 – id列

基于案例理解MySQL执行计划

3、执行计划包含的信息 – select_type列

基于案例理解MySQL执行计划 基于案例理解MySQL执行计划

4、执行计划包含的信息 – table列

基于案例理解MySQL执行计划

5、执行计划包含的信息 – type列cost对比

基于案例理解MySQL执行计划

type列示例

基于案例理解MySQL执行计划

6、执行计划包含的信息 – key列

基于案例理解MySQL执行计划

7、执行计划包含的信息 – ref与rows

基于案例理解MySQL执行计划

8、执行计划包含的信息 – filtered列

基于案例理解MySQL执行计划

9、执行计划包含的信息 – extra列

基于案例理解MySQL执行计划

基于案例理解MySQL执行计划


以上所述就是小编给大家介绍的《基于案例理解MySQL执行计划》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

ASP.NET 4高级程序设计(第4版)

ASP.NET 4高级程序设计(第4版)

Matthew MacDonald / 博思工作室 / 人民邮电出版社 / 2011-6 / 148.00元

《ASP.NET 4高级程序设计(第4版)》,本书是ASP.NET领域的鸿篇巨制,全面讲解了ASP.NET4的各种特性及其背后的工作原理,并给出了许多针对如何构建复杂、可扩展的网站从实践中得出的建议。一起来看看 《ASP.NET 4高级程序设计(第4版)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具