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值将会丢失。 

posted @ 2018-01-31 09:36  -Mark  阅读(335)  评论(0编辑  收藏  举报