Mysql的内部结构以及一条sql语句是如何去执行的

1.首先我们先来介绍一下MYSQL的内部结构

               1.1 MYSQL的内部结构分为serv层和存储引擎层,serv层里面包含连接器,分析器,查询缓存,优化器,执行器等,存储引擎层的话就是我们平时所说的InnoDB、MyISAM、Memory等存储引擎,主要负责数据的存取,在MYSQL5.0过后默认InnoDB。

1.2下面我准备了一条sql给大家讲解一下 MYSQL的执行顺序

SELECT * FROM USER WHERE ID=2

1.3 首先会先连接到数据库,然后到达我们的连接器,连接器这个时候就会对我们输入的用户名,端口,密码等等进行校验

1.4连接器校验完成后,就会先去查询缓存,如果命中缓存,就会直接返回结果,如果没有的话就会来到我们的分析器,分析器就会去检查我们的语法啊,是否正确,查询的表,条件啊是否存在等,例如下面的一条sql语句

SELEC *FORM WHERE ID=5

这里我们少写了一个C,这个时候当我们去执行的时候分析器这里就会直接给我们报一个错

 这就是分析器,

1.5 分析器通过过后,就会来到我们的优化器,优化器他会安装自己的方式去优化我们的sql,例如先执行什么后执行,那种方式效率为高一点

1.6最后来到我们的执行器,执行完输出结果集

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值