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

来源:互联网 发布:药品入库软件 编辑:程序博客网 时间:2024/05/22 00:28

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