面试官:mysql重启后自增id是从几开始增加

在 mysql 重启后就会存在 ID 重置问题。**删除数据后,再重启,AUTO_INCREMENT 会查询表里最大 ID 并进行重置,重置后和重启前AUTO_INCREMENT 计数器的值不同。**在 MyISAM 引擎表中的自增列不会存在这个问题。
面试官:mysql重启后自增id是从几开始增加
在mysql中用自增列作为主键时,先往表里插入5条数据,此时表里数据id为1、2、3、4、5,如果此时删除id=4、5的数据后,再重启数据库,重启成功后向表里插入数据的时候,innodb、myisam引擎下ID分别是从几开始增加? 如果你没经历过,或者当面试时被问到这个问题时,相信多数人都是一脸懵逼。MD 谁有事没事去重启线上数据库嘛。最主要的是很多没有测试过这个场景,没有这方面的经验,我在这里做个笔记,大家轻喷!
MySQL 通常使用的引擎都是 INNODB,在建表时,一般使用自增列作为表的主键,这样的表对提高性能有一定的帮助。但是自增列有一个坑,并且这个坑存在了很久,一直到 MySQL 8.0 版本,才修复了这个坑,这个坑就是表的自增列变量 auto_increment 在 MySQL 重启后,有可能丢失。
在 MySQL 低版本中,InnoDB 表中使用自增的 auto-increment 计数器 会把值存放在内存中,不会写入磁盘。一旦 MySQL 服务重启,这个值就丢了,InnoDB 引擎会根据表中现有的数据重新计算该计数器的值:获取表中最大的自增主键 ID 作为auto-increment 计数器的最大计数,当 insert 数据时,在 auto-increment 计数器最大值上 1。
先创建一张 user 表,新增几条数据:
向 user 表里插入 5 条数据,主键 ID 按自增列通过 auto-increment 计数器实现自增。
在 user 表里删除 id 为 4、5 的数据,再向 user 表中插入一条数据,主键 ID 是 auto-increment 的值 6。
mysql 数据库重启后,innodb 自增主键 ID 会根据 auto-increment 计数器的重置而重置。
在场景一的基础上,在删除 id 为 6、3 的数据后,此时 auto-increment 计数器的值为 7,user 表里的 id 最大是 2。
然后重启数据库后,auto-increment 计数器的值变为 3,也就是 user 表里的自增列 ID 的最大值 2 加 1。
此时在插入数据时,自增 ID 会从 3 开始自增。Innodb 表中把自增列作为主键 ID 时,在 mysql 重启后就会存在 ID 重置问题。**删除数据后,再重启,AUTO_INCREMENT 会查询表里最大 ID 并进行重置,重置后和重启前AUTO_INCREMENT 计数器的值不同。**在 MyISAM 引擎表中的自增列不会存在这个问题。
在 MySQL 8.0 中,这个计数器的逻辑变了:每当计数器的值有变,InnoDB 会将其写入 redo log,保存到引擎专用的系统表中。MySQL 正常关闭后重启:从系统表中获取计数器的数值。MySQL 故障后重启:从系统表中获取计数器的值;从最后一个检查点开始扫描 redo log 中记录的计数器值;取这两者的最大值作为新值。
总结
如果 mysql 重启了,那么 innodb 表在启动后,AUTO_INCREMENT 会自动检测出、并重置为当前表中自增列的最大值 +1。2)假如一个表格里 AUTO_INCREMENT 计数器的值是 10,此时执行update table set id = 15 where id = 9后,如果这时再继续插入数据,到了自增 ID=15 的时候是会报错。但是这个时候继续插入,就不会报错。因为刚才即使报错了,AUTO_INCREMENT 的值依旧会增加。3)现在使用的一般都是 innodb 引擎,如果将 myisam 引擎转换过来的时候,一定要小心这个引擎在自增 id 上的不同表现。在主从使用不同引擎的时候,也会出现问题,最好将引擎改完一致性的。
2022-07-02
mengvlog 阅读 8 次 更新于 2025-07-20 04:27:44 我来答关注问题0
  • 然后重启数据库后,auto-increment 计数器的值变为 3,也就是 user 表里的自增列 ID 的最大值 2 加 1。此时在插入数据时,自增 ID 会从 3 开始自增。Innodb 表中把自增列作为主键 ID 时,在 mysql 重启后就会存在 ID 重置问题。**删除数据后,再重启,AUTO_INCREMENT 会查询表里最大 ID...

  •  文暄生活科普 面试官问:MySQL的自增 ID 用完了,怎么办?

    线程id是一种常见的自增id,通常在MySQL的show processlist查询结果的第一列中出现。系统维护全局变量thread_id_counter,每次创建新连接时,将当前值赋给新连接的线程变量。由于thread_id_counter的大小为4字节,达到2^32-1后会重置为0并继续递增,导致数据覆盖。在实际运用中,我们有时会选择外部自增...

  •  翡希信息咨询 mysql自增id列怎么设置?

    在MySQL中设置自增ID列的步骤如下:创建表时设置自增ID列:在CREATE TABLE语句中,指定一个列并使用AUTO_INCREMENT关键字来将其设置为自增列。例如:sqlCREATE TABLE your_table_name , PRIMARY KEY );这里,id列被设置为自增列,并作为表的主键。2. 修改现有表以添加自增ID列: 使用ALTER TABL...

  •  翡希信息咨询 MYSQL的自增ID

    IDENTITY是系统定义的全局变量,表示最近一次向具有identity属性的表插入数据时对应的自增列的值。注意:在MySQL中,@@IDENTITY实际上是LAST_INSERT_ID的同义词,但LAST_INSERT_ID更为常用和推荐。使用限制:需要在insert操作后,且连接未关闭时执行,否则将得到NULL值。使用SHOW TABLE STATUS:通过查询表的...

  •  翡希信息咨询 面试官问:MySQL的自增 ID 用完了,怎么办?

    当MySQL的自增ID用完时,可以采取以下几种解决方案:扩展ID字段的长度:如果当前自增ID字段是INT类型,可以考虑将其更改为BIGINT类型。这将极大扩展ID的上限。使用外部生成ID:采用如Redis这样的外部系统生成ID。Redis具有原子性操作,可以保证高并发下的线程安全。通过结合时间戳和自增数来生成全局唯一的...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部