MySQL高级八:SQL执行流程
SQL执行流程
一、SQL执行流程图
1.
二、查询缓存
- 查看“查询缓存”功能状态
- 在/etc/my.cnf中设置query_cache_type的值 query_cache_type=0 :默认,表示查询缓存功能关闭 query_cache_type=1 :表示查询缓存功能开启 query_cache_type=2 :表示查询缓存功能按需使用
- 查询缓存功能按需使用 // 使用查询缓存功能 SELECT SQL_CACHE * FROM t_user WHERE id=5; // 不使用查询缓存功能 SELECT SQL_NO_CACHE * FROM t_user WHERE id=5;
三、解析器
- 词法分析 你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面 的字符串分别是什么,代表什么。
- 语法分析 根据语法规则,判断你输 入的这个 SQL 语句是否 满足 MySQL 语法 。如果语法正确,就会生成语法树。
- 语法树
四、优化器
- 作用 经过解析器后,MySQL知道了要做什么,但是可以有多种执行方法,故在执行之前,还需要经过优化器的处理,找到其中最好的执行计划。
- 物理优化 通过索引和表连接等技术进行优化
- 逻辑优化 在SQL语句的写法上进行更改,从而提高执行效率
五、执行器
- 判断用户是否具有权限 如果没有权限就不执行,如果有权限,就根据表的引擎定义,调用相关的存储引擎API
- 调用存储引擎API 存储引擎API只是一个抽象接口,下面还有一个存储引擎层。
- 执行器图示
六、SQL执行过程测试
- 设置profiling的值 select @@profiling; show variables like %profiling%; set @@profiling = 1;
- 查看SQL执行过程 show profiles; show profile for query 5;