上图为MySQL逻辑架构图,从图中可以看到MySQL可以分为Server层和存储引擎层两部分。
Server层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等。
存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持InnoDB、MyISAM、Memory等多个存储引擎。现在最常用的存储引擎是InnoDB,它从MySQL 5.5.5版本开始成为了默认存储引擎。也就是说,当执行create table语句建表时,如果不指定引擎类型,默认使用的就是InnoDB。不过,也可以通过指定存储引擎的类型来选择别的引擎,比如在create table语句中使用engine=memory, 来指定使用内存引擎创建表。不同存储引擎的表数据存取方式不同,支持的功能也不同。
从图中不难看出,不同的存储引擎共用一个Server层,也就是从连接器到执行器的部分。接下来我们依次介绍Server层中的每个组件。
连接器
连接器负责跟客户端建立连接、获取权限、维持和管理连接。客户端一般使用如下命令与服务端建立连接
mysql -h$ip -P$port -u$user -p
该命令参数为MySQL服务器IP、端口以及用户名和密码,如果用户名密码认证通过,连接器