首页 > 数据库技术 > 详细

[MySQL] 数据库自增ID用完了会怎么样

时间:2021-01-08 14:58:38      阅读:36      评论:0      收藏:0      [点我收藏+]

1.有主键
如果设置了主键,并且一般会把主键设置成自增。
我们知道,Mysql里int类型是4个字节,如果有符号位的话就是[-2^31,2^31-1]无符号位的话最大值就是2^32-1,也就是4294967295

如果超过上限就会看到错误提示:1062 - Duplicate entry ‘2147483647‘ for key ‘PRIMARY‘, Time: 0.000000s。
也就是说,如果设置了主键并且自增的话,达到自增主键上限就会报错重复的主键key。
解决方案,mysql主键改为bigint,也就是8个字节

2.没有主键
如果没有设置主键的话,InnoDB则会自动帮你创建一个6个字节的row_id,由于row_id是无符号的,所以最大长度是2^48-1

如果超过上限row_id会从0重新开始计算 , 覆盖旧数据

[MySQL] 数据库自增ID用完了会怎么样

原文:https://www.cnblogs.com/taoshihan/p/14250610.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!