栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

「MySQL 数据库 存储引擎」InnoDB和MyIsAm的区别

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

「MySQL 数据库 存储引擎」InnoDB和MyIsAm的区别

我们应该深刻意识到Mysql数据库的核心为存储引擎
MySql数据库的插件型体系结构,可以使用不同的存储引擎—— 而每个存储引擎都有各自的特点,开发人员可以根据不同的业务和应用建立不同的存储引擎表。
存储引擎主要分为官方存储引擎和第三方存储引擎,具有代表性的就是MyIsAm存储引擎和InnoDB存储引擎,下面说一说两者的区别。

InnoDB特点
  1. MySQL数据库在 5.5.8版本之前默认的存储引擎是MyIsAm,而5.5.8之后默认使用InnoDB
  2. InnoDB支持存储引擎支持事务,MyIsAm不支持
  3. InnoDB支持外键,MyIsAm不支持
  4. InnoDB支持表级锁和行级锁,MyIsAm只支持表级锁
  5. InnoDB支持级联更新,级联删除
  6. InnoDB使用MVCC(多版本并发控制协议)获得高并发性,支持四种标准的隔离级别,默认为 REPEATABLE READ(可重复读)
  7. InnoDB利用next_key_locking策略避免幻读,其相当于间隙锁和记录锁,不仅会锁住范围,还会锁住记录本身
  8. InnoDB提供了 加速插入操作的插入缓冲二次写、在内存中建立hash索引以加速读操作的自适应哈希索引,磁盘读取数据时采用了可预测预读等功能

没有无用的存储引擎,要根据业务做适当调整

MyIsAm特点
  1. 非事务存储引擎,究其原因,并非所有应用都需要事务,例如数据仓库(其中不涉及ETL操作,只有简单的报表查询,不需要事务)
  2. 只支持表级锁,并发性能较差,但是锁开销小
  3. 支持全文索引
  4. 缓冲池只缓存索引文件,不缓存数据文件
  5. 存储引擎由MYD和MYI组成,分别存放数据文件和索引文件(可以理解成MyData和MyIndex),由frm文件存储表
  6. MYD和MYI可以用myisampack工具进一步压缩,压缩后是只读文件,用户如果想要修改,只能用该工具解压->修改->再压缩
  7. 压缩表极大减少了磁盘空间的占有,因此可以压缩后可以减少磁盘I/O,提升查询效率;压缩表也支持索引,索引也是只读的
  8. myisampack工具使用哈夫曼编码静态算法压缩数据
  9. MySQL5.0之前指向数据记录的指针长度是4字节,因此表的大小只有4GB;5.0之后指针长度默认是6字节,因此默认支持256TB的单表数据
  10. 想要改变MyIsAm表指针的长度,可以通过修改MAX_ROWS和 AVG_ROW_LENGTH 两个参数的值,二者乘积就是表的最大大小
  11. 修改以上两个参数会导致重建整个表的所有索引,需要很长时间完成✅

以上!
总结自《高性能MySQL》、《InnoDB技术内幕》

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/606250.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号