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语句的写法上进行更改,从而提高执行效率
五、执行器
六、SQL执行过程测试
-
设置profiling的值
select @@profiling; show variables like '%profiling%'; set @@profiling = 1;
-
查看SQL执行过程
show profiles; show profile for query 5;