mysql自增长id用完了该怎么办


Posted in MySQL onFebruary 12, 2022

mysql自增长id用完了,怎么办?

作为一名程序员,在求职面试时,不知你有没有遇到类似这样的问题。

张工是一名java程序员,最近到一家互联网公司面试,面试官就问了他这样的一个问题。

面试官:"用过mysql吧,你们数据表主键id是用自增主键还是UUID?"   

张工:"用的是自增主键"    

面试官:"为什么是自增主键?"    

张工:"因为采用自增主键,数据在物理结构上是顺序存储,性能好"    

面试官:"那自增主键达到最大值了,用完了怎么办?"    

张工:“用完了就用完了,再申请呗”

面试官:“你可以回去等通知了”

今天我们就来谈一谈,这个自增主键用完了该怎么办?

在mysql,int整型的范围如下int的取值范围为:-2^31——2^31-1,即-2147483648—2147483647

如图:

mysql自增长id用完了该怎么办

以无符号整型为例,存储范围为0~4294967295,约43亿。当自增id达到最大值时,这是继续插入会出现什么异常呢,

我们来动手实践下。

首先,创建一张表tb_user,这张表只包含一个自增id

create table  tb_user(id int unsigned auto_increment primary key) ;

然后向这张表插入一条数据:

insert into tb_user values(null);

通过show命令show create table tb_user;查看表情况:

CREATE TABLE `tb_user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8

细心的你会发现 AUTO_INCREMENT 已经变成2,不过这离最大值4294967295远着呢,要想让它变成4294967295得插入非常多的记录,其实不用这么麻烦,我们可以在创建表的时候,直接声明AUTO_INCREMENT的初始值。

把我们刚才的创建表语句调整下,先把刚才的表删除掉,然后在创建表时加上auto_increment = 4294967295

create table tb_user(id int unsigned auto_increment primary key) auto_increment = 4294967295;

 然后同样往表插入一条记录

insert into tb_user values(null);

同样,我们通过show命令,查看表tb_user的表结构:

CREATE TABLE `tb_user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4294967295 DEFAULT CHARSET=utf8

通过

select * from tb_user

我们查询到id 为4294967295,已经是最大值,这时候如果再

当想往表在尝试插入一条数据时,报一个主键冲突异常如下所示。

[SQL]insert into tb_user values(null);
[Err] 1062 - Duplicate entry '4294967295' for key 'PRIMARY'

这可以说明,当再次插入时,使用的自增ID还是4294967295,就会报主键冲突的异常了。

4294967295,这个数字已经可以应付大部分的场景了,如果你的服务会经常性的插入和删除数据的话,还是存在用完的风险。

建议采用bigint unsigned,这个数字就大了。

那有什么办法解决,答案是肯定的,解决方法也是很简单的,将Int类型改为BigInt类型,BigInt的范围如下

-2^63-1到2^63-1

-9223372036854775808  9223372036854775807

mysql自增长id用完了该怎么办

就算每秒往数据表插入10000条数据,运行100年,来看看数据量有多少

10000*24*3600*365*100=31536000000000

这数字距离BigInt的上限还差的远,因此你将自增ID设为BigInt类型,就可以解决问题了。

如果你在面试中是这样回答面试官的。

你:"这还不简单,把自增主键的类型改为BigInt类型就可以解决了!"

面试官:"你在线上怎么修改列的数据类型的?"   

你:"alter table tb_user change id  id bigint;"

面试官:“你有实际操作经验吗?”

你:“…………没有实际操作过”

需要注意的是,这种方式在myl5.6+才开始支持,mysql支持在线修改数据库表,在修改表的过程中,对绝大部分操作,原表可读,也可以写。

对于修改数据类型这种操作,是不支持并发的DML操作!也就是说,如果你直接使用alter这样的语句在线修改表数据结构,会导致这张表无法进行更新类操作(delete、update、insert)。所以,想在生产线上执行修改表结构这样的方案是不可行的。

那有没有更好的方式,对于这个问题,我们以后再做讨论。

不知你有没有留意到这样一种情况,虽然主键自增ID是从0开始的,也就是说,现在可以用的范围为0~2147483647,但实际数据中有些id的值并不是连续的。

要是实际生产表出现单表超过上亿的数据量了,这时候想再往数据表写数据,性能肯定是受影响了,得赶紧考虑分库分表了。

一旦分库分表了,我们就不能依赖于每个表的自增id来全局唯一标识这些数据了。此时,我们就需要提供一 个全局唯一的id号生成策略来支持分库分表的环境。

所以在实际中,根本等不到自增主键用完的情况。

较友好的回答不妨参考这样的

面试官:"那自增主键达到最大值了,用完了怎么办?"   

你:这问题没遇到过,因为自增主键我们用int类型,一般达不到最大值,就要考虑分表分库了。

要是面试官穷追不舍,继续问你有关分库分表的要点,你也就可以针对性地回答,说明你完全有这方面的开发经验,相信能为这次面试加分。

总结:

mysql数据库表的自增 ID 达到上限之后,这时候再申请它的值就不会在改变了,如果继续插入数据就会导致报主键冲突异常。

因此在做数据字典设计时,要根据业务的需求来选择合适的字段类型。

到此这篇关于mysql自增长id用完了该怎么办的文章就介绍到这了,更多相关mysql自增长id内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
Apr 05 MySQL
MySQL下使用Inplace和Online方式创建索引的教程
May 26 MySQL
MySQL中的布尔值,怎么存储false或true
Jun 04 MySQL
MySQL8.0.18配置多主一从
Jun 21 MySQL
MySql 缓存查询原理与缓存监控和索引监控介绍
Jul 02 MySQL
Mysql关于数据库是否应该使用外键约束详解说明
Oct 24 MySQL
教你使用VS Code的MySQL扩展管理数据库的方法
Jan 22 MySQL
MySQL之MyISAM存储引擎的非聚簇索引详解
Mar 03 MySQL
MySQL派生表联表查询实战过程
Mar 20 MySQL
MySQL数据库简介与基本操作
May 30 MySQL
MySQL索引失效场景及解决方案
Jul 23 MySQL
MySQL 原理与优化之原数据锁的应用
Aug 14 MySQL
mysql下的max_allowed_packet参数设置详解
Feb 12 #MySQL
mysql聚集索引、辅助索引、覆盖索引、联合索引的使用
详解MySql中InnoDB存储引擎中的各种锁
Mysql忘记密码解决方法
Mysql存储过程、触发器、事件调度器使用入门指南
Jan 22 #MySQL
MySQL数据库⾼可⽤HA实现小结
weblogic服务建立数据源连接测试更新mysql驱动包的问题及解决方法
Jan 22 #MySQL
You might like
10款PHP开源商城系统汇总介绍
2015/07/23 PHP
PHP版本升级到7.x后wordpress的一些修改及wordpress技巧
2015/12/25 PHP
PHP Imagick完美实现图片裁切、生成缩略图、添加水印
2016/02/22 PHP
浅谈PHP中其他类型转化为Bool类型
2016/03/28 PHP
PHP未登录自动跳转到登录页面
2016/12/21 PHP
javascript 匿名函数的理解(透彻版)
2010/01/28 Javascript
IE6图片加载的一个BUG解决方法
2010/07/13 Javascript
给jqGrid数据行添加修改和删除操作链接(之一)
2011/11/04 Javascript
Jquery 例外被抛出且未被接住原因介绍
2013/09/04 Javascript
通过javascript把图片转化为字符画
2013/10/24 Javascript
AngularJS学习笔记之ng-options指令
2015/06/16 Javascript
Nodejs初级阶段之express
2015/11/23 NodeJs
实现JavaScript的组成----BOM和DOM详解
2016/05/18 Javascript
浅谈JavaScript异步编程
2017/01/20 Javascript
iview中Select 选择器多选校验方法
2018/03/15 Javascript
AngularJS中的作用域实例分析
2018/05/16 Javascript
JS中的两种数据类型及实现引用类型的深拷贝的方法
2018/08/12 Javascript
js动态设置select下拉菜单的默认选中项实例
2018/08/21 Javascript
vue-cli 项目打包完成后运行文件路径报错问题
2019/07/19 Javascript
Vue 中 a标签上href无法跳转的解决方式
2019/11/12 Javascript
JS实现分页导航效果
2020/02/19 Javascript
基于redis的小程序登录实现方法流程分析
2020/05/25 Javascript
手把手教你实现 Promise的使用方法
2020/09/02 Javascript
从零开始学Python第八周:详解网络编程基础(socket)
2016/12/14 Python
Python爬虫常用库的安装及其环境配置
2018/09/19 Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
2021/01/01 Python
Avène雅漾美国官方网站:敏感肌肤护理专家
2016/10/24 全球购物
德国最大的网上鞋店之一:Schuhe24.de
2017/06/10 全球购物
优秀员工表扬信
2014/01/17 职场文书
2014年创卫实施方案
2014/02/18 职场文书
毕业生求职信范文
2014/06/29 职场文书
PhpSpreadsheet中文文档 | Spreadsheet操作教程实例
2021/04/01 PHP
Python 多线程之threading 模块的使用
2021/04/14 Python
Python一行代码实现自动发邮件功能
2021/05/30 Python
Mybatis-plus在项目中的简单应用
2021/07/01 Java/Android
win10识别不了U盘怎么办 win10系统读取U盘失败的解决办法
2022/08/05 数码科技