MySQL高级八:SQL执行流程

SQL执行流程

一、SQL执行流程图

1.在这里插入图片描述

二、查询缓存
  1. 查看“查询缓存”功能状态

    在这里插入图片描述

  2. 在/etc/my.cnf中设置query_cache_type的值

    query_cache_type=0 :默认,表示查询缓存功能关闭

    query_cache_type=1 :表示查询缓存功能开启

    query_cache_type=2 :表示查询缓存功能按需使用

    在这里插入图片描述

  3. 查询缓存功能按需使用
    // 使用查询缓存功能
    SELECT SQL_CACHE * FROM t_user WHERE id=5;
    
    // 不使用查询缓存功能
    SELECT SQL_NO_CACHE * FROM t_user WHERE id=5;
    
三、解析器
  1. 词法分析

    你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面 的字符串分别是什么,代表什么。

  2. 语法分析

    根据语法规则,判断你输 入的这个 SQL 语句是否 满足 MySQL 语法 。如果语法正确,就会生成语法树。

  3. 语法树

    在这里插入图片描述

四、优化器
  1. 作用

    经过解析器后,MySQL知道了要做什么,但是可以有多种执行方法,故在执行之前,还需要经过优化器的处理,找到其中最好的执行计划。

  2. 物理优化

    通过索引和表连接等技术进行优化

  3. 逻辑优化

    在SQL语句的写法上进行更改,从而提高执行效率

五、执行器
  1. 判断用户是否具有权限

    如果没有权限就不执行,如果有权限,就根据表的引擎定义,调用相关的存储引擎API

  2. 调用存储引擎API

    存储引擎API只是一个抽象接口,下面还有一个存储引擎层。

  3. 执行器图示

    在这里插入图片描述

六、SQL执行过程测试
  1. 设置profiling的值

    select @@profiling;
    show variables like '%profiling%';
    set @@profiling = 1;
    

    在这里插入图片描述

    在这里插入图片描述

  2. 查看SQL执行过程

    show profiles;
    show profile for query 5;
    

    在这里插入图片描述

    在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

e_nanxu

感恩每一份鼓励-相逢何必曾相识

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值