开发人员基本都知道,我们的数据存在数据库中(目前最多的是mysql和oracle,由于作者更擅长mysql,所以这里默认数据库为mysql),服务器通过sql语句将查询数据的请求传入到mysql数据库。数据库拿到sql语句以后。都是进行了哪些操作呢?这里向大家介绍下我的个人的理解,欢迎大家评论区批评指正。
流程概述
mysql得到sql语句后,大概流程如下:
1.sql的解析器:负责解析和转发sql
2.预处理器:对解析后的sql树进行验证
3.查询优化器:得到一个执行计划
4.查询执行引擎:得到数据结果集
5.将数据放回给调用端。
流程图如下所示:
分发器及缓存阶段
首先,如果系统的缓存功能开启着的话,sql语句进入mysql后,sql进行判断,是否为select关键字。如果是,那么先去查询缓存中进行查询,如果在查询缓存中可以命中sql语句,那么直接返回查询缓存中的查询语句对应的value值(在缓存中,把查询语