一条 SQL 查询语句是如何执行的?

要是面试问到这个问题,回答不上来,都不好意思说自己会mysql。。。

sql查询语句执行步骤

        连接到mysql

        mysql8.0以前没有特别配置,会查询缓存,sql语句为key,如果有value,接下来检查用户是否对数据库,表是否有查询权限,权限校验通过就返回缓存结果,否则进入分析器

        分析器进行语法分析、词法分析,检查sql的语法顺序等得到解析树, 然后预处理器对解析树进一步分析,验证数据表、字段是否存在,通关之后sql进入下一步优化器

        优化器优化sql执行用的索引,连表查询的执行顺序,得到最终的执行计划。

        执行器调用存储引擎api执行sql,得到响应结果, 将结果返回给客户端,执行之前要先判断有没有执行权限。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值