1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 「MySQL 数据库 存储引擎」InnoDB和MyIsAm的区别

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

时间:2023-05-27 12:58:52

相关推荐

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

我们应该深刻意识到Mysql数据库的核心为存储引擎

MySql数据库的插件型体系结构,可以使用不同的存储引擎—— 而每个存储引擎都有各自的特点,开发人员可以根据不同的业务和应用建立不同的存储引擎表。

存储引擎主要分为官方存储引擎和第三方存储引擎,具有代表性的就是MyIsAm存储引擎和InnoDB存储引擎,下面说一说两者的区别。

InnoDB特点

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

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

MyIsAm特点

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

以上!

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。