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;
经验分享 程序员 微信小程序 职场和发展