MySQL 可以分为 Server 层和存储引擎层两部分
Server 层包括连接器、查询缓存、分析器、优化器、执行器等
存储引擎层则负责数据的存储和提取
这篇主要是看看Server的架构组成
1.连接器
负责将客户端和要连接的数据库建立连接。也就是在命令窗口输入命令后,会在交互对话里输入密码,如果用户名或者密码不对会报错,然后客户端程序结束执行;如果全部通过且没有权限限制,就相当连接成功了。可以敲show processlist;验证连接状态
如果长时间没动静,连接器就会自动将它断开,这个时间是由参数 wait_timeout 控制的,默认值是 8 小时
数据库里面,长连接是指连接成功后,如果客户端持续有请求,则一直使用同一个连接。短连接则是指每次执行完很少的几次查询就断开连接,下次查询再重新建立一个
2.查询缓存
建立连接后,就可以执行select语句了,但是通常MySQL在拿到一个查询请求后,会先查缓存。如果语句不在查询缓存中,就会继续后面的执行阶段。执行完成后,执行结果会被存入查询缓存中。如果查询命中缓存,MySQL 不需要执行后面的复杂操作,就可以直接返回结果。
查询已经存在的数据库 :SHOW DATABASES;
3.分析器
真正开始执行语句,MySQL 需要知道你要做什么,因此需要对 SQL 语句做解析
输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串分别是什么,代表什么。MySQL 从你输入的"select"这个关键字识别出来,这是一个查询语句。它也要把字符串“T”识别成“表名 T”,把字符串“ID”识别成“列 ID,一旦语句不对就会收到错误提示
4.优化器
在知道你要做什么之前,还要经过优化器的处理。总结说就是选择哪种最优方案就去完成语句的分析
5.执行器
上面的步骤都处理完成后,就开始进入执行过程了,开始执行语句
开始执行的时候,要先判断一下你对这个表 T 有没有执行查询的权限,如果没有,就会返回没有权限的错误,如果有,就打开表继续执行。打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口,到这里一个语句就执行完成了