一、sql执行顺序
from -> on -> join -> where -> group by -> having -> select -> distinct -> order by -> limit
其中,MySQL中where的执行顺序是从左往右,因此,筛选粒度最大的放在最左边这样效率最高。
二、mysql架构
主要分为server层和存储引擎层。
server层主要分为连接器、解析器、优化器、执行器和查询缓存;
存储引擎层与数据的读写操作有关,是MySQL与物理磁盘交互的部分,在mysql中以插件形式使用。
连接器:主要负责给用户创建并维护连接以及用户的认证和鉴权;
查询缓存:如果开启了查询缓存,那么查询操作时如果查询缓存中有这条sql的结果,那么直接就从查询缓存中取,不需要进行后续步骤。当有DML和DQL操作时,会清空查询缓存。一般不建议使用,MySQL8之后已经去除查询缓存的功能。
解析器:主要有两个功能词法解析和语法解析。词法解析是根据空格将sql语句拆分,拆分出关键字和非关键字(表、数据库名)进行处理。语法解析是进行sql语法校验,检查是否符合sql标准并分析是DDL、DML、DCL还是DQL语句。
优化器:优化索引,会选择一个索引进行使用,并将where条件的顺序进行一定的优化,形成执行计划。DQL和DML会走到优化器(因为有where条件)。
执行器:将优化后的执行计划,调用存储引擎层,完成对应的操作。
三、一次sql的执行过程
客户端发送sql :
select * from t where id = 1
服务端的执行过程:
1.连接器与客户端建立连接,判断用户名密码和权限;
2.查询缓存中,有-> 直接返回 没有-> 进行下面的步骤;
3.调用解析器进行词法和语法分析,形成一棵二叉搜索树,并判断要进行何种操作(DDL,DML,DCL, DQL);
4.调用优化器,对sql进行优化,形成执行计划,选择使用一个索引进行搜索;
5.调用执行器按照执行计划调用存储引擎层;
6.将结果返回给客户端,并存储在查询缓存中。