mysql知识(1)

一、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.将结果返回给客户端,并存储在查询缓存中。

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值