MySQL——(一)MyISAM和InnoDB两种存储引擎有什么区别?

MyISAM和InnoDB两种存储引擎有什么区别?

总览

  • MyISAM是MySQL 5.5版本以前默认的数据库引擎
  • InnoDB弥补了MyISAM的一些不足,在5.5版本以后称为数据库的默认引擎,逐渐取代了MyISAM

一、MyISAM

  1. MyISAM强调性能每次查询具有原子性,不提供事务支持

  2. 只支持表级锁,select、update、delete、insert语句都会给表自动加锁。MyISAM在同一个表上的读锁和写锁是互斥的,如果既有读请求又有写请求,即使读请求先到,写请求优先级也会更高

  3. 所以MyISAM不适合有大量查询和修改并存的情况,那样查询进程会长时间阻塞。因为MyISAM是锁表,在某项读操作比较耗时会使得其他写进程饿死

  4. MyISAM允许没有任何索引和主键的表存在不支持外键

  5. 每个MyISAM表在磁盘上存储成三个文件:

    – .frm文件:存储表定义

    – .MYD文件:存储数据

    – .MYI文件:存储索引

  6. 索引和数据分离,这样在内存里可以缓存更多的索引,对查询的性能会更好,适用于那种少量的插入,大量查询的场景

使用MyISAM最常见的场景就是报表系统

  1. 基于Hadoop生态,用HDFS来存储数据,然后基于Hive来进行数仓建模,每次Hive跑出来的数据都用Sqoop导出到MySQL中去

  2. 基于MySQL,搭建J2EE的在线报表查询Web系统,每个报表开发一套代码,写对应的查询SQL,组织数据,按照前端要求的格式返回数据,展现出来一个报表

  3. 这种报表系统,是最适合MySQL的MyISAM存储引擎的,因为它并不需要事务的支持,就是在最初的时候一次性批量导入大量数据,然后基于这些属性开始查询

二、InnoDB

  1. InnoDB支持事务,它的AUTO_COMMIT默认是打开的。意味着每条SQL语句都会被默认封装成一个事务,自动提交。由于事务的处理会影响速度,所以最好是把多条SQL语句组成一个事务一起提交,减少数据库多次提交锁导致的开销,以此提高性能。

  2. 支持行级锁,大幅度提高了多用户并发操作的性能。但是InnoDB的行锁,只是在WHERE的主键是有效的,非主键的WHERE还是会锁全表

  3. 支持外键,如果没有设定主键或者非空唯一索引,会自动生成一个6字节的主键(用户不可见)

  4. 表的所有内容都保存在同一个数据文件中,索引和数据并不分开,InnoDB表的大小只受限于操作系统文件的大小,一般为
    2GB

  5. InnoDB需要更多的内存和存储,它会在主存中建立其专用的缓冲池用于高速缓冲数据和索引。数据和索引是绑定到一起的,当我们要单独缓冲数据或索引的时候,这两部分内容会进行绑定缓冲。

MyISAMInnoDBMemory
由frm、myd、myi三个文件组成由frm、ibd两个文件组成定义在frm文件中
不支持事务支持事务数据存放在内存中,访问效率高
提供表级锁提供行级锁提供表级锁
不支持外键支持外键----
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值