MySQL MyISAM默认存储引擎实现原理

Samira ·
更新时间:2024-09-20
· 656 次阅读

默认MyISAM的表会在磁盘中产生3个文件:.frm(表结构文件)、.MYD(数据文件)、.MYI(索引文件)

  可以在创建的时候指定数据文件和索引文件的存储位置,只有MyISAM表支持:

    DATA DIRECTORY [=] 数据保存的绝对路径     INDEX DIRECTORY [=] 索引文件的绝对路径

  MyISAM单表最大支持的数据量为2的64次方跳记录  

  每个表最多可以建立64个索引

  如果是复合索引,每个复合索引最多包含16个列,索引值最大长度是1000B

  MyISAM引擎的存储格式:

    定长(FIXED 静态) :是指字段不包含VARCHAR/TEXT/BLOB     动态(DYNAMIC) :只要字段中包含了VARCHAR/TEXT/BLOB     压缩(COMPRESSED):muisampack创建

InnoDB存储引擎:

  设计遵循ACID模型,支持事务,具有从服务崩溃中恢复的能力,能够最大限度保护用户的数据

  支持行级锁,可以提升多用户并发时的读写性能

  InnoDB拥有自己独立的缓冲池,常用的数据和索引都在缓存中

  对于INSERT、UPDATE、DELETE操作,InnoDB会使用一种change buffering的机制来自动优化,还可以提供一致性的读,并且还能够缓存变更的数据,减少磁盘I/O,提高性能

  创建InnoDB表之后会产生两个文件:

    .frm表结构文件     .ibd 数据和索引存储表空间中

  所有的表都需要创建主键,最好是配合上AUTO_INCREMENT,也可以放到经常查询的列作为主键

您可能感兴趣的文章:MySQL存储引擎MyISAM与InnoDB区别总结整理Mysql更换MyISAM存储引擎为Innodb的操作记录总结MySQL存储引擎中MyISAM和InnoDB区别详解Mysql存储引擎MyISAM的常见问题(表损坏、无法访问、磁盘空间不足)MySQL存储引擎中的MyISAM和InnoDB区别详解Mysql存储引擎InnoDB和Myisam的六大区别Mysql 的存储引擎,myisam和innodb的区别



存储 myisam 存储引擎 Mysql

需要 登录 后方可回复, 如果你还没有账号请 注册新账号