上一篇文章主要介绍了MySQL在Ubuntu18.04系统上的安装,以及安装过程中可能会遇到的一些问题的解决方案。
在这篇文章里,开始介绍MySQL数据库的逻辑分层。通过本文的介绍,可以大致了解到MySQL的语句从客户端发出请求后,在服务器经历了怎样的过程。有助于后面MySQL优化的加深理解。
MySQL逻辑分层
一般来说,MySQL逻辑可分为四个层次,分别为:连接层,服务层,引擎层,存储层 。
连接层
提供与客户端连接的服务。
当客户端发出一个请求后(如增删改查的SQL语句),首先到达该层,将服务器与客户端建立连接。
服务层
服务层分两个作用:
提供各种用户使用的接口。 如select、insert等
提供SQL优化器(MySQL Query Optimizer)。 SQL优化器是MySQL服务层自带的一个服务,它会自动优化用户写得不是最优的SQL,使其达到优化的效果。但由于优化器毕竟只是优化器,有时候会将用户自定义的优化方案给更改掉,从而使用户自己的优化方案失效,这一点需要注意。
引擎层
引擎层提供各种数据存储的方式。MySQL的存储引擎有很多,比较常用的比如有InnoDB, MyISAM。
InnoDB与MyISAM的区别为:
InnoDB 事务优先,所以适合高并发操作,使用的是行锁
MyISAM 性能优先,适合查询多的场景,使用的是表锁
查询数据库支持哪些引擎的SQL:
mysql> show engines;
+