知识分享之MariaDB——MyISAM与Innodb引擎的区别
背景
日常我们开发时,我们会遇到各种各样的奇奇怪怪的问题(踩坑o(╯□╰)o),这个常见问题系列就是我日常遇到的一些问题的记录文章系列,这里整理汇总后分享给大家,让其还在深坑中的小伙伴有绳索能爬出来。 同时在这里也欢迎大家把自己遇到的问题留言或私信给我,我看看其能否给大家解决。
开发环境
- 系统:windows10
- 数据库:MariaDB
内容
目前国内使用MariaDB/MySQL数据库的有很多,但是很多小伙伴可能不了解该数据库创建一个库时是需要根据实际情况进行使用不同的内置引擎的,下面我就对于常用的两种引擎进行做一下对比,便于有需要的小伙伴们快速选择出当前场景下需要使用的引擎。
类型 | MyISAM引擎 | Innodb引擎 |
---|---|---|
事务支持性 | 不支持,非事务型,高速存储和检索 | 事务型,支持4个事务隔离级别 |
适用场景 | 查询类占整个软件的大部分,并发性弱的场景 | 新增、修改等占整个软件的大部分 |
锁支持 | 表锁 | 行锁、表锁 |
存储方式 | 划分为三个文件,.frm表定义、.MYD数据、.MYI索引 | 表空间数据文件、日志文件两部分,表大小受限于操作系统文件的大小,通常默认2G |
并发性 | 读写互相阻塞 | 可重复读,需注意事务隔离级别 |
查询效率性 | 高效 | 相比低效,因其查询时执行的环节要多 |
总结: 仅有查询没有高并发,用MyISAM 必须用事务,用Innodb 大量插入或修改,用Innodb 全文检索,用MyISAM 高并发:Innodb
本文声明:
本作品由 cn華少 采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。