一、mysql存储引擎


MyISAM、InnoDB、MEMORY、MERGE、ARCHIVE


二、每种引擎的优缺点


  1. MyISAM无法处理事务。
    适用场景:选择密集型的表--MyISAM在筛选大量数据时非常迅速;插入密集型的表--MyISAM的并发插入特性允许同时选择和插入数据。
    应用:管理邮件或web服务器日志信息。
  2. InnoDB:
    适用场景:更新密集的表--InnoDB适用多重并发的更新请求;事务;自动灾难恢复;外键约束;支持自动增加列AUTO_INCREMENT属性。
    5.7新特性:透明压缩、加密、虚拟列。
  3. MEMORY:逻辑存储介质是系统内存,但当mysqld守护进程崩溃时,所有memory数据都会丢失。同时要求数据表中使用的数据时长度不变的格式,这意味着不能使用BLOB、TEXT这样的长度可变的类型,但可以使用varchar,因为varchar在Mysql内部是定长的char类型。
    适用场景:目标数据较小,而且被频繁的使用;数据临时,又要求立即可用。
  4. MERGE:一组MyISAM的集合。
  5. ARCHIVE:仅支持最基本的插入和查询操作,MySql 5.5之后开始支持索引,有很好的压缩机制,经常被当做仓库使用。