MYSQL体系结构:
- 连接层
- 最上层是一些客户端和链接服务,主要完成一些类似于连接处理,授权认证、及相关的安全方案。
- 服务器也会为安全接入的每个客户端验证其所具有的操作权限。
- 服务层
- 第二层架构主要完成大多数的核心服务功能,如SQL接口,并完成缓存查询,SQL的分析和优化,
- 部分内置函数的执行,所有跨存储引擎的功能也在这一层实现,如过程、函数等。
- 引擎层
- 存储引擎正在的负责了MYSQL中数据的存储和提取,服务器通过API和存储引擎进行通信。
- 不同的存储引擎具有不同的功能,这样我们可根据自己的需求,来选取合适的存储引擎。
- 存储层
- 主要是将数据存在在文件系统之上,并完成与存储引擎的交互。
存储引擎:
存储引擎,就是存储数据、建立索引、更新/查询数据等技术的实现方式。
存储引擎是基于表的,而不是基于库的,所以存储引擎也可被称为表类型。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | 例如: -- ----------------------------------存储引擎---------------------------------- show create table tb_users; CREATE TABLE `tb_users` ( `id` int (11) NOT NULL AUTO_INCREMENT COMMENT '主键' , ` name ` varchar (100) NOT NULL COMMENT '姓名' , `age` int (11) DEFAULT NULL , `status` char (1) DEFAULT '1' COMMENT '状态' , `gender` char (1) DEFAULT NULL COMMENT '性别' , `phone` varchar (11) DEFAULT NULL COMMENT '手机号' , PRIMARY KEY (`id`), UNIQUE KEY ` name ` (` name `) ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4 COLLATE =utf8mb4_0900_ai_ci COMMENT= '用户表' -- InnoDB 默认存储引擎 -- ----------------------------------存储引擎---------------------------------- |
-- 查看当前数据库支持的存储引擎
show engines;
注:在创建表结构时,可通过 engine=存储引擎,为其指定存储引擎,例如:engine=MyISAM......
存储引擎的特点:
- InnoDB
- 介绍:InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,在Mysql5.5之后,InnoDB是默认的Mysql存储引擎。
- 特点:
- DML操作遵循ACID模型,支持事务(DML--数据的增删改操作)
- 行级锁,提高并发访问性能
- 支持外键约束,保证数据的完整性和正确性
- 文件:xxx.ibd,xxx代表的是表名,innoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frm、sdi)、数据和索引
- 参数:innodb_file_per_table
- show VARIABLES like 'innodb_file_per_table'; —— innodb_file_per_table ON 表示每张表对应一个表控件文件
-
- MyISAM
- MyISAM是MySQL早期的默认存储引擎。
- 特点:
- 不支持事务、不支持外键
- 支持表锁,不支持行锁
- 访问速度快
- 文件:
- xxx.sdi:存储表结构信息
- xxx.MYD:存储数据
- xxx.MYI:存储索引
- Memory
- Memory引擎的表数据是存储在内存中的,由于受到硬件问题、或断电问题的影响,只能将这些表作为临时表或缓存使用。
- 特点:
- 内存存放
- hash索引(默认)
- 文件:
- xxx.sdi:存储表结构信息
存储引擎选择:
在选择存储引擎时,应根据应用系统的特点选择合适的存储引擎。
对于复杂的应用系统,还可以根据实际情况选择多种存储引擎进行组合。
InnoDB |
是MySQL的默认引擎,支持事务、外键。 如果应用程序对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操纵除了插入和查询之外,还包含 很多的更新、删除操纵,则比较适合选择InnoDB。 适用性高 |
MyISAM |
如果应用以读操纵和插入操作为主,只有很少的更新和删除操纵,并且对事务的完整性、并发性要求不是很高,则可选择。 --被NoSql替代(Mongodb) |
Memory |
将所有数据保存在内存中。访问速度快,通常用于临时表及缓存。 其缺陷就是对表的大小有限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。 --被redis替代 |
博客内容主要用于日常学习记录,内容比较随意,如有问题,还需谅解!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
2017-07-17 XmlHelper