暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL中的自增主键

原创 wzf0072 2023-04-12
362

MySQL中的自增主键

 

MySQL的主键可以是自增的,那么如果在断电重启后新增的值还会延续断电前的自增值吗?自增值默认为1,那么可不可以改变呢?下面就说一下 MySQL的自增值。


特点


保存策略

1、如果存储引擎是 MyISAM,那么这个自增值是存储在数据文件中的;

2、如果是 InnoDB引擎,1)在 5.6之前是存储在内存中,没有持久化,在重启后会去找最大的键值,举个例子,如果一个表当前数据行里最大 id是10,AUTO_INCREMENT=11。这时候,我们删除 id=10 的行,AUTO_INCREMENT 还是 11。但如果马上重启实例,重启后这个表的 AUTO_INCREMENT 就会变成 10;

          2)在 8.0开始,自增值就保存在 redo log中,重启后会从 redo log中读取之前保存的自增值。


自增值的确定

1、如果插入数据时 id字段指定为0、null或未指定,那么就把这个表当前的 AUTO_INCREMENT值填到自增字段,并且会以auto_increment_offset作为初始值,auto_increment_increment为步长,找出第一个大于当前自增值的值作为新的自增值。

2、如果插入的数据的 id字段指定了具体的值,就直接使用语句里的值。

在一些场景下,使用的就不全是默认值。比如,双 M 的主备结构里要求双写的时候,我们就可能会设置成 auto_increment_increment=2,让一个库的自增 id 都是奇数,另一个库的自增 id 都是偶数,避免两个库生成的主键发生冲突。


自增值的修改

假设某次要输入的值是 X,当前的自增值是 Y。那么:

1、如果 X<Y,那么这个表的自增值不变;

2、如果X≥Y,那么就把当前自增值修改为新的自增值。


执行过程

假设有表t ,id是自增主键,在已有 (1,1,1)的情况下,插入一条 (null,1,1),那么执行过程就如下:

1、执行器调用 InnoDB 引擎接口写入一行,传入的这一行的值是 (0,1,1);

2、InnoDB 发现用户没有指定自增 id 的值,获取表 t 当前的自增值 2;

3、将传入的行的值改成 (2,1,1);

4、将表的自增值改成 3;

5、继续执行插入数据操作,由于已经存在 c=1 的记录,所以报 Duplicate key error,语句返回。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论