Mysql存储引擎对比之:innoDB与MyISAM

MyISAM:这个是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的顺序访问方法) 的缩写,它是存储记录和文件的标准方法。与其他存储引擎比较,MyISAM具有检查和修复表格的大多数工具。 MyISAM表格可以被压缩,而且它们支持全文搜索。它们不是事务安全的,而且也不支持外键。如果事物回滚将造成不完全回滚,不具有原子性。如果执行大量的SELECT,MyISAM是更好的选择。

  1. 两种类型最主要的差别在于InnoDB支持事务和行级锁,而MyISAM不支持
  2. MyISAM的读性能比InnoDB强很多
  3. MyISAM的索引和数据是分开的,并且索引是有压缩的,内存使用率就对应提高很多,二而InnoDB是索引和数据捆绑的,所以InnoDB的体积会大不少
  4. SELECT * … 操作是锁表的,InnoDB的行级锁只针对WHERE条件是主键有效,非主键是锁定全表的
    • 表级锁,直接锁定整张表,在你锁定期间,其它进程无法对该表进行写操作。如果你是写锁,则其它进程则读也不允许(MyISAM)
    • 行级锁,仅对指定的记录进行加锁,这样其它进程还是可以对同一个表中的其它记录进行操作(例如:InnoDB)
    • 页级锁,表级锁速度快,但冲突多,行级冲突少,但速度慢。所以取了折衷的页级,一次锁定相邻的一组记录(例如:BDB)
  5. InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的
  6. InnoDB不支持FULLTEXT类型的索引
  7. InnoDB是事务安全的,还支持外键
  8. 对于AUTO_INCREMENT类型的字段,InnoDB必须包含只有该字段的索引,MyISAM可以和其他字段一起建立联合索引
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值