首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 主键自增不连续

基础概念

MySQL中的主键自增(AUTO_INCREMENT)是一个用于生成唯一标识符的特性,通常用于表的主键列。当插入新记录时,如果没有为该列指定值,MySQL会自动为该列生成一个唯一的、递增的整数值。

相关优势

  1. 唯一性:自增主键确保每条记录都有一个唯一的标识符。
  2. 简化插入操作:插入新记录时无需手动指定主键值。
  3. 性能优化:自增主键可以提高索引的性能,因为索引是按照递增顺序构建的。

类型

MySQL中的自增主键通常是整数类型(如INT、BIGINT),但也可以是其他支持自增的类型。

应用场景

自增主键广泛应用于需要唯一标识符的场景,如用户表、订单表等。

问题:自增不连续的原因及解决方法

原因

  1. 删除记录:删除某些记录后,自增主键不会回退,导致后续插入的记录主键值跳过被删除的值。
  2. 手动插入值:如果手动插入了主键值,可能会导致自增序列不连续。
  3. 事务回滚:在事务中插入记录,如果事务回滚,自增主键值不会回退。
  4. 服务器重启:某些情况下,服务器重启可能导致自增主键值不连续。

解决方法

  1. 忽略删除的影响:如果删除记录不影响业务逻辑,可以接受自增主键不连续。
  2. 使用序列(Sequence):某些数据库系统支持序列,可以生成连续的自增值。MySQL本身不支持序列,但可以通过其他方式模拟。
  3. 手动管理自增值:通过程序逻辑手动管理自增值,确保连续性。
  4. 使用复合主键:如果业务允许,可以使用复合主键(多个列组成主键),而不是单一的自增主键。

示例代码

以下是一个简单的MySQL表结构示例,展示了自增主键的使用:

代码语言:txt
复制
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    email VARCHAR(100) NOT NULL UNIQUE
);

参考链接

通过以上信息,您可以更好地理解MySQL自增主键的概念、优势、类型、应用场景以及自增不连续的原因和解决方法。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 自增主键不连续的几种情况

    //自增主键不连续的几种情况// 最近在极客时间上学习丁奇大佬的《MySQL 45讲》,这里结合自己的理解分享出来,喜欢的同学可以购买原版课程进行学习,里面的内容很丰富。...代表的是自增主键的开始值,而increment代表的是自增主键每次的增长值。...02 事务回滚导致的自增键不连续 当我们使用回滚事务的时候,如果该事务内部使用了自增值,那么同样会导致表自增主键出问题,示例如下: mysql> insert into t values (null...03 MySQL自增锁优化带来的不连续 在MySQL5.7中,参数innodb_autoinc_lock_mode被用来控制自增锁的模式,该参数可以设置为三个值:0、1、2. a、当该值为0的时候,...为了避免自增id不连续而造成的主从数据不一致,线上环境,建议设置成innodb_autoinc_lock_mode=2 ,并且 binlog_format=row.这样做,既能提升并发性,又不会出现数据一致性问题

    3.5K30

    mysql 主键自增语句_MySQL 自增主键

    连续性 插入成功时,其数据的 ID 和前一次插入成功时数据的 ID 相邻。 自增主键的单调性 为何会有单调性的问题? 这主要跟自增主键最大值的获取方式,以及存放位置有关系。...自增主键最大值怎么取的?存放到哪里?...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...自增主键插入时的连续性 这里不考虑由于删除导致的连续性问题 为何会有连续性问题? 这主要是跟插入事务回滚有关系。 对于两个插入事务,事务 A 先执行插入语句,之后事务 B 执行插入语句。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

    10.8K10

    mysql主键自增策略_MySQL 自增主键机制

    自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪? 不同的存储引擎保存自增值的策略不一样; a....对于MyISAM引擎,自增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...每次重启后第一次打开表,都会去查找自增值的最大值max(id), 并设置表当前自增值为max(id) + 1; mysql8.0, 自增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...自增值修改发生在插入数据的操作之前,如果插入失败,自增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 的策略(注:该策略是导致自增 id 不连续的第三种原因

    9.5K50

    MySQL 的自增主键一定是连续

    但实际上,MySQL 的自增主键并不能保证一定是连续递增的。...更遗憾的是,即使在自增初始值和步长这两个参数都设置为 1 的时候,自增主键 id 也不一定能保证主键是连续的 自增值不连续场景 2 举个例子,我们现在往表里插入一条 (null,1,1) 的记录,生成的主键是...所以,在这之后,再插入新的数据行时,拿到的自增 id 就是 3。也就是说,出现了自增主键不连续的情况。...至此,我们已经罗列了两种自增主键不连续的情况: 自增初始值和自增步长设置不为 1 唯一键冲突 除此之外,事务回滚也会导致这种情况 自增值不连续场景 3 我们现在表里有一行 (1,1,1) 的记录,AUTO_INCREMENT...自增值不连续场景 4 对于批量插入数据的语句,MySQL 有一个批量申请自增 id 的策略: 语句执行过程中,第一次申请自增 id,会分配 1 个; 1 个用完以后,这个语句第二次申请自增 id,会分配

    3.8K10

    MySQL重大Bug!自增主键竟然不是连续递增

    很多低级开发工程师都想当然觉得自增主键是严格连续递增的,但事实真的如此吗?...此后再成功插入新数据,拿到自增id就是3了 如你所见,自增主键不连续了!所以唯一键冲突是导致自增主键id不连续的一大原因。 事务回滚是二大原因。...因为原库session2的insert语句,生成的id不连续。这个不连续的id,用statement格式的binlog来串行执行,是执行不出来的。...要解决该问题,有如下方案: 让原库的批量插入数据语句,固定生成连续id值 所以,自增锁直到语句执行结束才释放,就是为了达此目的 在binlog里把插入数据的操作都如实记录进来,到备库执行时,不依赖自增主键去生成...这是主键自增id不连续的三大原因。

    2.6K00

    MySQL重大Bug!自增主键竟然不是连续递增

    很多低级开发工程师都想当然觉得自增主键是严格连续递增的,但事实真的如此吗?...此后再成功插入新数据,拿到自增id就是3了 如你所见,自增主键不连续了!所以唯一键冲突是导致自增主键id不连续的一大原因。 事务回滚是二大原因。...因为原库session2的insert语句,生成的id不连续。这个不连续的id,用statement格式的binlog来串行执行,是执行不出来的。...要解决该问题,有如下方案: 让原库的批量插入数据语句,固定生成连续id值 所以,自增锁直到语句执行结束才释放,就是为了达此目的 在binlog里把插入数据的操作都如实记录进来,到备库执行时,不依赖自增主键去生成...这是主键自增id不连续的三大原因。

    3.6K10

    不懂就问:MySQL 自增主键一定是连续的吗?

    测试环境: MySQL版本:8.0 数据库表:T (主键id,唯一索引c,普通字段d) 如果你的业务设计依赖于自增主键的连续性,这个设计假设自增主键是连续的。...三、自增主键值不连续情况:(唯一主键冲突) 当我执行以下SQL语句时 insert into t values(null, 1, 1); 第一次我们可以进行新增成功,根据自增值的修改机制。...所以,在这之后,再插入新的数据行时,拿到的自增 id 就是 3。也就是说,出现了自增主键不连续的情况。...四、自增主键值不连续情况:(事务回滚) 其实事务回滚原理也和上面一样,都是因为异常导致新增失败,但是自增值没有进行回退。...五、自增主键值不连续情况:(批量插入) 批量插入数据的语句,MySQL 有一个批量申请自增 id 的策略: 语句执行过程中,第一次申请自增 id,会分配 1 个; 1 个用完以后,这个语句第二次申请自增

    19210

    MySQL自增主键值回溯问题

    平时我们使用MySQL时,通常每一个表都会有一个自增主键ID,每新增一条数据,ID值就会自增1。但在8.0之前版本的MySQL中,这个自增值会存在一个回溯的问题。...例如,在一个新表中插入三条主键为1、2、3的数据行,这时候用SHOW CREATE TABLE命令查看该表的AUTO_INCREMENT的值是4,这是没问题的。...但如果重启一下MySQL,这个值就会变回3,而不是4,发生了回溯。...这是因为AUTO_INCREMENT的值只存储于内存中,不会持久化到磁盘,每次启动数据库时,MySQL会通过计算max(auto_increment字段) + 1,重新作为该表下一次的主键ID的自增值。...这个问题直至MySQL 8.0才修复。 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149188.html原文链接:https://javaforall.cn

    4.2K20

    MySQL 主键自增注意事项

    很多小伙伴应该知道,在 MySQL 中主键不应该使用随机字符串。但是主键不用随机字符串用什么?主键自增?主键自增就是最佳方案吗?有没有其他坑?今天我们就来讨论下这个话题。 1....基于上面的分析,我们在 MySQL 中尽量不使用 UUID 作为主键,不用 UUID,可能会有小伙伴想到,那我使用主键自增行不行?...主键自增有没有一些需要注意的问题? 2. 主键自增的问题 以下内容,有一个共同的大前提,就是我们的表设置了主键自增。 一般来说,主键自增是没有什么问题的。但是,如果在高并发环境下,就会有问题了。...SQL 语句开始的时候,获取到一个表级的 AUTO-INC 锁,然后当插入 SQL 执行完毕之后,再释放掉这把锁,这样做的好处是可以确保在批量插入的时候,自增主键是连续的。...2: 这个表示 interleaved,这种情况下不存在 AUTO-INC 锁,来一个处理一个,批量插入的时候,就有可能出现主键虽然自增,但是不连续的问题。

    13510

    MySQL自增主键详解「建议收藏」

    (初始值)开始,以auto_increment_increment(步长)为步长,持续叠加,直到找到第一个大于X的值,作为新的自增值 三、自增值的修改时机 创建一个表t,其中id是自增主键字段、c是唯一索引...出现了自增主键不连续的情况 唯一键冲突和事务回滚都会导致自增主键id不连续的情况 四、自增锁的优化 自增id锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 但在MySQL5.0版本的时候...自增锁还是要等语句结束后才被释放 3.这个参数设置为2,所有的申请自增主键的动作都是申请后就释放锁 为了数据的一致性,默认设置为1 如果sessionB申请了自增值以后马上就释放自增锁,那么就可能出现这样的情况...所以,自增锁直到语句执行结束才释放,就是为了达到这个目的 2)在binlog里面把插入数据的操作都如实记录进来,到备库执行的时候,不再依赖于自增主键去生成。...之后,再执行insert into t2 values(null, 5,5),实际上插入了的数据就是(8,5,5) 这是主键id出现自增id不连续的第三种原因 五、自增主键用完了 自增主键字段在达到定义类型上限后

    5.9K40

    mysql为什么建议使用自增主键

    我们都知道表的主键一般都要使用自增 id,不建议使用业务 id ,是因为使用自增 id 可以避免页分裂。这个其实可以相当于一个结论,你都可以直接记住这个结论就可以了。...如果主键为自增 id 的话,mysql 在写满一个数据页的时候,直接申请另一个新数据页接着写就可以了。...如果主键是非自增 id,为了确保索引有序,mysql 就需要将每次插入的数据都放到合适的位置上。...其实对主键 id 还有一个小小的要求,在满足业务需求的情况下,尽量使用占空间更小的主键 id,因为普通索引的叶子节点上保存的是主键 id 的值,如果主键 id 占空间较大的话,那将会成倍增加 mysql...本来这篇文章是打算总结一下前面写的几篇关于 mysql 索引的文章的,也是打算多举几个例子的,结果发现光写了一个自增主键就写了一大堆了,然后时间也比较晚了,干脆就写到这吧,原本计划的几个其他例子后面再单独写吧

    5K31

    MySQL 主键 自增 ID 会用完吗?

    MySQL 主键 自增 ID 会用完吗?...首先我们一般创建 MySQL 数据表的时候,大部分情况下会创建一个自增主键ID 的字段,可能你的建表语句如下: CREATE TABLE IF NOT EXISTS `tb`( `id` INT...所以 在 MySQL 中 自增 ID 是会用完的。那么问题来了,加入他的 ID 用完会发生什么事呢? 我们来验证下。...如果会那么久需要创建 8 字节的 INT 类型了,他的值最大是 2^64-1 那么问题又来了,你说 我有些业务是不需要主键 、不需要自增编号,我不创建这个字段,就好了,这样想恭喜你 回答错误....总结: 自增 ID 用完 会报主键冲突、数据插入失败。 不指定主键、默认创建的 row_id 会 覆盖原有的数据。

    9.6K20

    MySQL实战第三十九讲-自增主键为什么不是连续的?

    之前我见过有的业务设计依赖于自增主键的连续性,也就是说,这个设计假设自增主键是连续的。但实际上,这样的假设是错的,因为自增主键不能保证连续递增。...所以,在这之后,再插入新的数据行时,拿到的自增 id 就是 3。也就是说,出现了自增主键不连续的情况。...如下图 3 所示,即一个自增主键 id 不连续的复现步骤: 可以看到,这个操作序列复现了一个自增主键 id 不连续的现场 (没有 id=2 的行)。...可见,唯一键冲突是导致自增主键 id 不连续的第一种原因。 同样地,事务回滚也会产生类似的现象,这就是第二种原因。 下面这个语句序列就可以构造不连续的自增 id,你可以自己验证一下。...这是主键 id 出现自增 id 不连续的第三种原因。 5. 小结 今天,我们从“自增主键为什么会出现不连续的值”这个问题开始,首先讨论了自增值的存储。

    99710

    数据库主键一定要自增吗?有哪些场景不建议自增?

    主键id不自增的情况 没有主键可以吗 mysql表如果没有主键索引,查个数据都得全表扫描,那既然它这么重要,我今天就不当人了,不声明主键,可以吗? 嗯,你完全可以不声明主键。...隐藏的row_id列 有没有建议主键不自增的场景 前面提到了主键自增可以带来很多好处,事实上大部分场景下,我们都建议主键设为自增。 那有没有不建议主键自增的场景呢?...数据库有那么多种,mysql只是其中一种,那其他数据库也是要求主键自增吗?...tidb的主键id不建议自增 tidb是一款分布式数据库,作为mysql分库分表场景下的替代产品,可以更好的对数据进行分片。...当然,主键保持自增,但是不暴露给前端,那也行,那前面的话,你当我没说过。

    6.6K33
    领券