MySQL高级八:SQL执行流程

SQL执行流程

一、SQL执行流程图

1.MySQL高级八:SQL执行流程_第1张图片

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

    MySQL高级八:SQL执行流程_第2张图片

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

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

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

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

    MySQL高级八:SQL执行流程_第3张图片

  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. 语法树

    MySQL高级八:SQL执行流程_第4张图片

四、优化器
  1. 作用

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

  2. 物理优化

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

  3. 逻辑优化

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

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

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

  2. 调用存储引擎API

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

  3. 执行器图示

    MySQL高级八:SQL执行流程_第5张图片

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

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

    MySQL高级八:SQL执行流程_第6张图片

    MySQL高级八:SQL执行流程_第7张图片

  2. 查看SQL执行过程

    show profiles;
    show profile for query 5;
    

    MySQL高级八:SQL执行流程_第8张图片

    MySQL高级八:SQL执行流程_第9张图片

你可能感兴趣的:(MySQL高级篇,mysql,sql,数据库)