MySQL存储引擎详解及对比和选择
创始人
2024-05-28 12:09:52
0

什么是存储引擎?

MySQL中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。

简单的来说存储引擎就是存储数据、建立索引、更新/查询数据等技术的实现方式,存储引擎是基于表的,而不是基于数据库的,所以存储引擎也可以成为表类型。

查看支持的引擎

show engines:

查看存储引擎

  • InnoDB

特点:支持事务,表锁,可靠性与性能高,适合高并发场景,以及事务完整性要求比较高的场景,空间占用比较大。 是MySQL中默认的引擎。

优点:提供良好的事务管理、崩溃修复能力和并发控制。

缺点:读写效率稍差,空间占用比较大。

  • MyISAM

特点:不支持事务,是MySQL早期的默认存储引擎,不支持外键,支持表锁,不支持行锁, 占用空间小,访问速度快。

优点:空间占用比较小,访问速度快。

  • Memory

特点:基于内存,Memory引擎的表数据时存储在内存中的,由于受到硬件问题、或断电问题的影响,只能将这些表作为临时表或缓存使用。

三种存储引擎对比和选择

  • InnoDB : 是Mysql的默认存储引擎,支持事务、外键。如果应用对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包含很多的更新、删除操作,那么InnoDB存储引擎是比较合适的选择。
  • MyISAM : 如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性、并发性要求不是很高,那么选择这个存储引擎是非常合适的。
  • MEMORY:将所有数据保存在内存中,访问速度快,通常用于临时表及缓存。MEMORY的缺陷就是对表的大小有限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。

存储引擎对比

创建一张表并且指定引擎

create table users(id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(10)
)engine=InnoDB

该SQL代表的意思即为:创建一 w张名为users的表,有id和username两个字段,并且设置引擎为InnoDB

相关内容

热门资讯

女孩柯在名字中的意思是什么? 女孩柯在名字中的意思是什么?我觉得“柯”很有明气
三八妇女节的短信笑话 三八妇女节的短信笑话今天裂野妇女解放了,还是少惹为妙!  ●恭喜你过节了,我来蠢饥做你来吃。一年肆档...
加油!王楚钦男单首轮出战蒯曼对... 来源: 央视新闻 【加油!#王楚钦男单首轮出战##蒯曼对...
好玩的回合制游戏有哪些? 好玩的回合制游戏有哪些?我也是回合制的老玩家了我一直在1314u平台玩.新梦幻之城这款游戏我们也是交...
石大胜华质押触发鹰眼“高风险”... 截止2025年7月5日,石大胜华整体质押股份为2270.10万股,整体质押占总股本之比为11.20%...
机器人“艾德”:车间搬运有绝活 单人站立时长超5小时、日均搬货量约1吨,人形机器人如何胜任车间物流任务?江南大学智能制造学院教授张秋...
天蚕土豆做发 天蚕土豆做发1.土豆用工具切成齿轮状,这工具网上都有卖的,没有工具切成条也行; 2.放清水浸泡一会;...
中信建投:港府双轨并行缓解住房... 中信建投证券发布研报称,香港地狭人稠,可利用土地不足,住房矛盾较为突出;政府通过市场轨和保障轨双轨并...
想知道哪里有《弟子规》《孝经》... 想知道哪里有《弟子规》《孝经》《大学》的电子版?还有,《孝经》《大学》有声书。去试下狗狗书籍如果没有...
在湖州沃土种出奋斗果实 转自:湖州日报  讲述人:浙江卉弘生物科技股份有限公司总经理郑云宇  前几天,当得知自己获评“湖州市...