MySQL 的两种存储引擎

MyISAM 是MySQL的默认数据库引擎(5.5以后默认是InnoDB)性能极佳,但不支持事务处理。

InnoDB 是MySQL的数据库常用的数据引擎。

MyISAM 和 InnoDB 两者之间有明显的区别,简单梳理一下:

  1. 事务

    • m:每次查询具有原子性,执行速度比i快但是不支持事务操作。
    • i:提供事务、回滚、崩溃修复能力的事务安全(ACID)型数据引擎
  2. 存储
    • m:每个m表在磁盘上存储成三个文件。分别是表定义文件(表名xx.frm)、数据文件(表名xx.MYD)、索引文件(表名xxx.MYI)。m还支持三种不同的存储格式,动态表,静态表,压缩表,存储开销依次变小,执行开销依次增大。
    • i:属于索引组织表。有两种存储方式,分别是共享表空间和多表空间存储。
      • 共享表空间:所有的表都保存在同一个数据文件中。i表文件的大小之受限于操作系统文件的大小。i在存储上需要更多的内存和磁盘空间,他会在主存中建立其专用的缓冲池用于高速存取数据与索引。
      • 多表空间存储:每个表都有一个表空间用于存储每个表的数据和索引 (表名.idb)。
  3. 数据移植、备份、恢复
    • m:数据是以稳健的形式存储,所以在跨平台的数据转移中会很方便。可以对单个表进行操作。
    • i:由于多个表保存在同一个文件中,只能拷贝整体文件,备份binlog,或者用mysqldump。
  4. 主键
    • m:允许没有任何索引和主键 的表存在,索引保存的是行的地址
    • i:如果没有设置主键或者非空唯一索引,就会自动生成一个6字节的主键(用户不可见),数据是主索引的一部分,附加索引保存的是主索引的值。
  5. 外键
    • m不支持外键,i支持。
  6. 索引
    • 全文索引:m全文索引不支持中文(中文需要sphinx),i也支持了(但可以用sphinx插件支持,效果还不错)
    • 另外,m索引和数据分离,天生非聚簇索引,最多有一个unique的性质。i的数据文件本身就是主键索引文件,这样的索引被称为聚集索引。
    • m引擎使用b+tree作为索引结构,叶节点的不存放实际数据,存放实际数据的地址,叫做非聚集索引。
    • i引擎也是用b+tree作为索引结构,但实现方式与m截然不同。一个重大区别是i的数据文件本身就是索引文件(而m索引文件是与数据文件分离的,主键索引与其他索引在实现上没有区别),子叶节点的数据域部分保存了完整的行记录,这个b+tree的key是表的主键,这种索引叫做聚集索引。
    • 但是,i中的其他索引在查询时就没有那么幸运了,需要先在其他索引中查询到对应主键,再在聚集索引中查找对应的行。
    • mysql支持三种锁定级别,行级,页级,表级别
    • m支持表级锁
    • i支持行级锁(where 字段是主键),表锁,但i的行锁也不是绝对的,当在执行一个sql语句且mysql不能确定要扫描的范围时,i同样会全表加锁,当确定范围时会加间隙锁。

      • update table set num = 1 where name like ‘%xxx%’; ---退化表锁
      • update table set num = 1 where name = 123             ---隐式转换 退化表锁
      • update table set num = 1 where id >50  -------------------间隙锁
  7. 并发
  8. auto_increment
  9. 表的具体行数

原文地址:https://www.cnblogs.com/chafanbusi/p/10657146.html

时间: 2024-11-10 06:29:43

MySQL 的两种存储引擎的相关文章

mysql的两种存储引擎

MySQL 有多种存储引擎,目前常用的是 MyISAM 和 InnoDB 这两个引擎,除了这两个引擎以为还有许多其他引擎,有官方的,也有一些公司自己研发的.这篇文章主要简单概述一下常用常见的 MySQL 引擎,一则这是面试中常被问到的问题,二则这也是数据库设计中不可忽略的问题,用合适的引擎可以更好的适应业务场景,提高业务效率. InnoDB引擎 InnoDB是一个事务型的存储引擎,支持回滚,设计目标是处理大数量数据时提供高性能的服务,它在运行时会在内存中建立缓冲池,用于缓冲数据和索引. Inno

谈谈MySQL两种存储引擎

Mysql有两种存储引擎:InnoDB与Myisam 二者之间有六大区别:   MyISAM InnoDB 构成上的区别: 每个MyISAM在磁盘上存储成三个文件.第一个 文件的名字以表的名字开始,扩展名指出文件类型..frm文件存储表定义.数据文件的扩 展名为.MYD (MYData).索引文件的扩 展名是.MYI (MYIndex). 基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的 大小只受限于操作系统文件的大小,一般为 2GB 事务处理上方面: MyISAM类

MySQL - 两种存储引擎 (MyISAM PK InnoDB) + MVCC

总结 1.两种存储引擎各有各的有点,MyISAM专注性能,InnoDB专注事务.两者最大的区别就是InnoDB支持事务,和行锁. 2.InnoDB采用MVCC(Multi-Version Concurrency Control 多版本并发控制)来支持高并发,一种行级锁的变种.MVCC是通过保存数据在某一个时间点的快照来实现的,也就是说无论事务执行多久,每个事务看到的数据都是一致的.InnoDB的MVCC,是通过在每行记录后面保存两个隐藏的列来实现,这两个列一个保存了行的创建时间,一个保存了行的过

Mysql两种存储引擎的优缺点

MyISAM引擎是一种非事务性的引擎,提供高速存储和检索,以及全文搜索能力,适合数据仓库等查询频繁的应用.MyISAM中,一个table实际保存为三个文件,.frm存储表定义,.MYD存储数据,.MYI存储索引.  NULL值被允许在索引的列中. 如何查看表的存储引擎 SHOW TABLE STATUS FROM 数据库 WHERE Name = '表名' InnoDB:这种类型是事务安全的.它与BDB类型具有相同的特性,它们还支持外键.InnoDB表格速度很快.具有比BDB还丰富的特性, 因此

MySQL 常见的两种存储引擎

MySQL两种常见的存储引擎有:MyISAM 和 InnoDB,两者区别如下: 1.count运算:MyISAM 有缓存表的 meta-data 元数据,元数据包括行数等,因此其做 COUNT(*) 查询时不需要消耗多少资源.而 InnoDB 就没有这个缓存. 2.事务和崩溃后的安全恢复:MyISAM强调的是性能,每次查询具备原子性,执行速度比 InnoDB 更快,但是 MyISAM 不提供事务的支持.而 InnoDB 支持事务.外部键等高级数据库功能.具有事务提交(commit).回滚(rol

MySQL两种存储引擎: MyISAM和InnoDB 简单总结

MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然性能极佳,但却有一个缺点:不支持事务处理(transaction).不过,在这几年的发展下,MySQL也导入了InnoDB(另一种数据库引擎),以强化参考完整性与并发违规处理机制,后来就逐渐取代MyISAM. InnoDB,是MySQL的数据库引擎之一,为MySQL AB发布binary的标准之一.InnoDB由Innob

MySql两种存储引擎的区别

MyISAM: 不支持事务,但是每次查询都是原子的: 支持表级锁,即每次操作是对整个表加锁: 存储表的总行数: 一个MYISAM表有三个文件:索引文件.表结构文件.数据文件: 采用菲聚集索引,索引文件的数据域存储指向数据文件的指针.辅索引与主索引基本一致,但是辅索引不用保证唯一性. InnoDb: 支持ACID的事务,支持事务的四种隔离级别: 支持行级锁及外键约束:因此可以支持写并发: 不存储总行数: 一个InnoDb引擎存储在一个文件空间(共享表空间,表大小不受操作系统控制,一个表可能分布在多

MySQL两种存储引擎: MyISAM和InnoDB总结

MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良.虽然性能极佳,但却有一个缺点:不支持事务处理(transaction).不过,在这几年的发展下,MySQL也导入了InnoDB(另一种数据库引擎),以强化参考完整性与并发违规处理机制,后来就逐渐取代MyISAM. InnoDB,是MySQL的数据库引擎之一,为MySQL AB发布binary的标准之一.InnoDB由Innob

MySQL的两个存储引擎

MyISAM 和InnoDB 讲解 InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定.基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持以及外部键等高级数据库功能. 以下是一些细节和具体实现的差别: ◆1.InnoDB不支持FULLTEXT类型的索引. ◆2.InnoDB 中不保存表的具体行数,