InnoDB和MyISAM 主键生成策略的区别

Posted codermark

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了InnoDB和MyISAM 主键生成策略的区别相关的知识,希望对你有一定的参考价值。

问:如果有一张表,里面有个字段为id的自增主键,当已经向表里面插入了10条数据之后,删除了id为8,9,10的数据,再把mysql重启,

之后再插入一条数据,那么这条数据的id值应该是多少,是8,还是11? 
答:如果表的类型为MyISAM,那么是11。如果表的类型为InnoDB,则id为8。 
这是因为两种类型的存储引擎所存储的最大ID记录的方式不同,MyISAM表将最大的ID记录到了数据文件里,重启mysql自增主键的最大ID值也不会丢失; 
而InnoDB则是把最大的ID值记录到了内存中,所以重启mysql或者对表进行了OPTIMIZE操作后,最大ID值将会丢失。 




以上是关于InnoDB和MyISAM 主键生成策略的区别的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL中MyISAM 和InnoDB索引的区别

Mysql引擎 Innodb和MyISAM的区别

Myisam索引和Innodb索引的区别

MyISAM和InnoDB在索引上的差别及其它区别

mysql存储方式MyISAM 和 InnoDB的区别

mysql中的InnoDB和MyISAM