MySQL原理

一条SQL语句的执行流程

  • Mysql 介绍
    • 1.Server 层
    • 2.存储引擎
    • 一条Sql语句的执行流程
    • 连接器
    • 查询缓存
    • 分析器
    • 优化器
    • 执行器

Mysql 介绍

一:MySQL 可以分为 Server 层和存储引擎层两部分。

1.Server 层

Server 层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖 MySQL
的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等。

2.存储引擎

众所周知Mysql的存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持 InnoDB、MyISAM、Memory
等多个存储引擎。现在最常用的存储引擎是 InnoDB,它从 MySQL 5.5.5 版本开始成为了默认存储引擎。 也就是说,你执行
create table 建表的时候,如果不指定引擎类型,默认使用的就是InnoDB。

1、InnoDB支持事务,而MyISAM不支持事务
2、InnoDB支持行级锁,而MyISAM支持表级锁
3、InnoDB支持MVCC, 而MyISAM不支持
4、InnoDB支持外键,而MyISAM不支持
5、InnoDB不支持全文索引,而MyISAM支持。

一条Sql语句的执行流程

下面我给出的是 MySQL 的基本架构示意图,从中你可以清楚地看到 SQL 语句在 MySQL 的各个功能模块中的执行过程。
MySQL原理_第1张图片

连接器

第一步,会先连接到这个数据库上,这时候接待你的就是连接器。连接器负责跟客户端建立连接、获取权限、维持和管理连接。连接命令中的 mysql 是客户端工具,用来跟服务端建立连接。在完成经典的 TCP 握手后,连接器就要开始认证你的身份,

这个时候用的就是你输入的用户名和密码。如果用户名或密码不对,你就会收到一个"Access denied for user"的错误

这里MySQL不能确定是用户名不正确还是密码不正确。不管用户名还是密码,两者任何一个不正确,都会返回access denied for user的错误。这样避免你知道用户名后,不断的修改密码尝试破解密码,不告诉你是账号名称不对,还是密码不对

如果用户名密码认证通过,连接器会到权限表里面查出你拥有的权限。之后,这个连接里面的权限判断逻辑,都将依赖于此时读到的权限。

这就意味着,一个用户成功建立连接后,即使你用管理员账号对这个用户的权限做了修改,也不会影响已经存在连接的权限。修改完成后,只有再新建的连接才会使用新的权限设置。

长连接,短连接

长连接是指连接成功后,如果客户端持续有请求,则一直使用同一个连接。
短连接则是指每次执行完很少的几次查询就断开连接,下次查询再重新建立一个。

查询缓存

第二步:执行select语句
简单来说,MySQL 拿到一个查询请求后,会先到查询缓存看看,之前是不是执行过这条语句。之前执行过的语句及其结果可能会以 key-value 对的形式,被直接缓存在内存中。key 是查询的语句,value 是查询的结果。如果你的查询能够直接在这个缓存中找到 key,那么这个 value 就会被直接返回给客户端。

  1. 但是我们平时不推荐使用查询缓存,为什么呢。因为当我们可能花很大精力把数据进行缓存,但是当我们对数据库进行更新时,查询缓存他会失效。这个时候查询缓存的命中率就会很低。如果一张表,可能很久更新一次,或者不经常更新,那么我们的查询缓存命中率会高一点。
  2. 注意:查询缓存在MySQL8.0之后被默认删除了。也就是MySQL8.0之后没有查询缓存这个功能。

分析器

第三步:当查询缓存没有命中时,会执行SQL语句。
分析器的主要功能是对我们写的SQL进行语法上的解析。

  1. 词法分析:对你写的SQL语句的词进行解析,比如你写的select id ,那么他就会解析这个id是什么,他代表什么。
  2. 语法分析:根据词法分析的结果,语法分析器会根据语法规则,判断你输入的这个 SQL 语句是否满足 MySQL 语法。

优化器

优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序。比如你执行下面这样的语句,这个语句是执行两个表的 join:

mysql> select * from t1 join t2 using(ID) where t1.c=10 and t2.d=20;
  1. 既可以先从表 t1 里面取出 c=10 的记录的 ID 值,再根据 ID 值关联到表 t2,再判断 t2 里面 d 的值是否等于 20。
  2. 也可以先从表 t2 里面取出 d=20 的记录的 ID 值,再根据 ID 值关联到 t1,再判断 t1 里面 c 的值是否等于 10。

这两种执行方法的逻辑结果是一样的,但是执行的效率会有不同,而优化器的作用就是决定选择使用哪一个方案。优化器阶段完成后,这个

执行器

MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。

开始执行的时候,要先判断一下你对这个表 T 有没有执行查询的权限,如果没有,就会返回没有权限的错误。如果有权限,就打开表继续执行。打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口。

mysql> select * from T where ID=10;
ERROR 1142 (42000): SELECT command denied to user 'b'@'localhost' for table 'T'

比如我们这个例子中的表 T 中,ID 字段没有索引,那么执行器的执行流程是这样的:

  1. 调用 InnoDB 引擎接口取这个表的第一行,判断 ID 值是不是 10,如果不是则跳过,如果是则将这行存在结果集中;
  2. 调用引擎接口取“下一行”,重复相同的判断逻辑,直到取到这个表的最后一行。
  3. 执行器将上述遍历过程中所有满足条件的行组成的记录集作为结果集返回给客户端。至此,这个语句就执行完成了。

你可能感兴趣的:(MySQL,mysql,数据库,java)