参考链接
什么是存储引擎
数据库存储引擎是数据库底层软件组件,数据库管理系统使用数据引擎进行创建、查询、更新和删除数据操作。不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能,使用不同的存储引擎还可以获得特定的功能。
现在许多数据库管理系统都支持多种不同的存储引擎,MySql的核心就是存储引擎
InnoDB事务型是数据数据库的首选引擎,支持事物安全表(ACID),支持行锁定和外键,MySQL5.5.5之后,InnoDB成为默认使用引擎
MyISMA
是基于ISMA的存储引擎,并对其进行扩展,是在Web,数据仓,和其他应用环境下最长使用的存储引擎,MyISMA拥有较高的插入,查询速度,但是不支持事物
MEMORY
存储引擎将表中的数据存储到内存中,为查询和引用其他数据提供快速访问
MySQL5.7支持的存储引擎
MySQL 支持多种类型的数据库引擎,可分别根据各个引擎的功能和特性为不同的数据库处理任务提供各自不同的适应性和灵活性。在 MySQL 中,可以利用 SHOW ENGINES 语句来显示可用的数据库引擎和默认引擎。
MySQL 提供了多个不同的存储引擎,包括处理事务安全表的引擎和处理非事务安全表的引擎。在 MySQL 中,不需要在整个服务器中使用同一种存储引擎,针对具体的要求,可以对每一个表使用不同的存储引擎。
MySQL 5.7 支持的存储引擎有 InnoDB
、MyISAM
、Memory
、Merge
、Archive
、Federated
、CSV
、BLACKHOLE
等。可以使用SHOW ENGINES语句查看系统所支持的引擎类型,结果如图所示。
-- 查看数据库系统支持的引擎,Support表示某种引擎是否能用,default表示当前使用的默认引擎
show engines;
Support 列的值表示某种引擎是否能使用,YES
表示可以使用,NO
表示不能使用,DEFAULT
表示该引擎为当前默认的存储引擎。
存储引擎的选择
功能 | MylSAM | MEMORY | InnoDB | Archive |
---|---|---|---|---|
存储限制 | 256TB | RAM | 64TB | None |
支持事务 | No | No | Yes | No |
支持全文索引 | Yes | No | No | No |
支持树索引 | Yes | Yes | Yes | No |
支持哈希索引 | No | Yes | No | No |
支持数据缓存 | No | N/A | Yes | No |
支持外键 | No | No | Yes | No |
可以根据以下原则选择存储引擎
- 如果要提供提交、回滚和恢复的事务安全(ACID 兼容)能力,并要求实现并发控制,InnoDB 是一个很好的选择。
- 如果数据表主要用来插入和查询记录,则 MyISAM 引擎提供较高的处理效率。
- 如果只是临时存放数据,数据量不大,并且不需要较高的数据安全性,可以选择将数据保存在内存的 MEMORY 引擎中,MySQL 中使用该引擎作为临时表,存放查询的中间结果。
- 如果只有 INSERT 和 SELECT 操作,可以选择Archive 引擎,Archive 存储引擎支持高并发的插入操作,但是本身并不是事务安全的。Archive 存储引擎非常适合存储归档数据,如记录日志信息可以使用 Archive 引擎。
MySQL的默认存储引擎
InnoDB 是系统的默认引擎,支持可靠的事务处理。
-- 修改数据库的默认存储引擎
set default_storage_engine=MyISAM;
此时,可以发现 MySQL 的默认存储引擎已经变成了 MyISAM。但是当再次重启客户端时,默认存储引擎仍然是 InnoDB。