MySQL的自增 ID 用完了,怎么办?

MySQL 自增 ID 一般用的数据类型是 INT 或 BIGINT,正常情况下这两种类型可以满足大多数应用的需求。

当然也有不正常的情况,当达到其最大值时,尝试插入新的记录会导致错误,错误信息类似于:

ERROR 167 (22003): Out of range value for column 'id' at row 1

下面我们就来看看  INT 或 BIGINT 到底能插入多少的数据。


1、INT 

INT 类型占用 4 个字节,范围:-2,147,483,648 到 2,147,483,647(如果是无符号类型,则范围是 0 到 4,294,967,295

也就是说 INT 类型存储量将近可以达到 43 亿,看着数量,感觉可以存储很多条记录了,我们就来计算下:

一年 365 天,一天 24 小时,一小时 60 分钟,一分钟 60 秒,如果每秒钟存储 100 条记录看看能用多久:

# INT 的最大值
max_int_value =  4294967295# 每秒记录数
records_per_second = 100# 每年的秒数
records_per_year = 365 * 24 * 60 * 60
result = max_int_value/(records_per_second * records_per_year)print(result)
# 结果:1.3619251950152207

结果就为 1.3619251950152207,也就是能存储 1 年多的时间,看来确实不太够,使用 INT 类型,如果数据量过多,自增 ID 很容易超过最大数值。


2、BIGINT

BIGINT 占用 8 个字节,范围:-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807(如果是无符号类型,则范围是 0 到 18,446,744,073,709,551,615

假如公司是我家,我准备在公司呆个 100 年,我们来计算下 BIGINT 使用 100 年支持每秒插入多少数据。

BIGINT 类型的最大值:

无符号 BIGINT 类型的最大值为18,446,744,073,709,551,615

计算 100 年的秒数:

100年×365天/年×24小时/天×60分钟/小时×60秒/分钟 = 3,153,600,000

# BIGINT 的最大值
max_bigint = 18446744073709551615# 100年的秒数
seconds_in_100_years = 365*24*60*60*100# 计算结果
result = max_bigint / seconds_in_100_yearsprint(result)
# 结果:5849424173.55072

结果为 5849424173.55072 相当于每秒钟插入 58 亿的数据,这样的数据双十一都不知道有没达到,我用 AI 查找了下淘宝双十一历史的最大并发生:

这样看,我如果使用 BIGINT,在公司干个 100 年完全没问题,即便公司能活 100 年,老板也活不过 120+(假设老板 20 岁出来继承家业),也就是即便我把老板送走,都达不到最大的值。

所以我们只要把自增 ID 设置为 BIGINT 类型,你根本就不用担心自增 ID 会用完,而是要担心公司能不能活的比 BIGINT 更长。

总结:

INT 类型在大多数情况下足够使用,当需要更大的数值范围时,可以考虑使用 BIGINT 类型。

如果你的自增 ID 是 INT  类型,要修改 INT 为 BIGINT 可以使用 ALTER 命令:

 

-- 创建表
CREATE TABLE orders (id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,order_data VARCHAR(255)
);
-- 查看表结构
DESCRIBE orders;
-- 修改自增列的数据类型
ALTER TABLE orders MODIFY id BIGINT UNSIGNED AUTO_INCREMENT;
-- 再次查看表结构,确认修改
DESCRIBE orders;

注意事项

  1. 备份数据:在进行表结构修改之前,最好备份数据,以防止操作过程中出现意外情况。

  2. 锁表:在修改表结构时,表可能会被锁定,导致短暂的写操作中断。尽量在业务低峰期进行操作。

  3. 外键约束:如果有外键约束涉及到要修改的列,需要先删除相关外键约束,修改列类型后再重新添加外键约束。

文章来源于菜鸟教程 ,作者RUNOOB

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/32921.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用SpringBootTest测试项目

当我们开发项目后,通常需要进行单元测试,确保开发符合预期。但是对于Springboot项目,依赖部分IOC容器对象的注入。比如代码中存在Autowired、Service、Mapper等。 1、确保pom.xml中包含了依赖,其中的version和scope,大…

【科普】半导体制造过程的步骤、技术、流程

在这篇文章中,我们将学习基本的半导体制造过程。为了将晶圆转化为半导体芯片,它需要经历一系列复杂的制造过程,包括氧化、光刻、刻蚀、沉积、离子注入、金属布线、电气检测和封装等。 基本的半导体制造过程 1.晶圆(Wafer&#xf…

发送ajax请求时由于click事件重复绑定导致的请求重复发送问题

问题场景 项目背景:CRM练习项目,通过复选框选择列表中的数据,用户点击删除按钮,弹出确认弹窗,用户点击确认后,前端分装数据到数组,发送ajax请求,将数据传递至Controller进行处理。 …

《计算机英语》测试练习题

作业3 一、单选题 内存条 的英文翻译是 A. memory chip (内存条通常指的是内存条上的存储芯片,但整个内存条的英文翻译应为 "RAM",即 Random Access Memory 随机存取存储器) capacitor的中文意思是 D. 电容器 relay 的解释是 A. 继电器 por…

基于CDMA的多用户水下无线光通信(2)——系统模型和基于子空间的延时估计

本文首先介绍了基于CDMA的多用户UOWC系统模型,并给出了多用户收发信号的数学模型。然后介绍基于子空间的延时估计算法,该算法只需要已知所有用户的扩频码,然后根据扩频波形的循环移位在观测空间的信号子空间上的投影进行延时估计。 1、基于C…

matplotlib之savefig函数

savefig函数 Matplotlib中,savefig函数用于保存图形为文件。通过该函数,你可以将绘制的图形保存为常见的图像文件格式,如PNG、JPEG、SVG等。 matplotlib.pyplot.savefig(fname, dpiNone, bbox_inchestight, pad_inches0.1, formatNone, tra…

分类接口开发

文章目录 1.查询所有一级分类1.sun-club-application-controller 控制层1.SubjectCategoryController.java 定义基础的queryPrimaryCategory,调用领域层 2.sun-club-domain 领域层1.SubjectCategoryDomainService.java2.SubjectCategoryConverter.java3.SubjectCate…

Python 算法交易实验72 QTV200第一步: 获取原始数据并存入队列

说明 最近的数据流往前进了一步,我觉得基本可以开始同步的推进QTV200了。上次规划了整体的数据流,现在开始第一步。 内容 1 结构位置 这是上次的总体图: 以下是这次要实现的一小部分: 从结构上,这个是整体数据流的…

力扣-接雨水

文章目录 概要题解解释代码比较左右高度处理右侧为什么双指针法有效 概要 原题链接:接雨水 题解 思路:双指针 核心思想:对于任意位置 i,能够存储的雨水量取决于位置 i 左侧和右侧的最大高度中的较小值减去 height[i]。即 min(le…

使用MySQL WorkBbench 连接远程服务器上的mysql教程(包含踩过的坑)

最近在学习MySQL,想要装一个可视化程序,但是希望把脏活累活留给服务器,于是自己电脑上安装了一个MySQL Workbench作为Client。下面记录一下配置的过程。 服务器端MySQL配置 安装MySQL这里就不赘述啦,可以参考 https://segmentfa…

路经总和-二叉树题

112. 路径总和 - 力扣(LeetCode) 1、用队列 两个队列,先进先出 node队列存节点; sum队列存每条路径走到这个节点的val的总和; 节点和总和对应着同时存入队列,同时出队列; class Solution …

springboot+vue+mybatis旅游管理+PPT+论文+讲解+售后

随着人民生活水平的提高,旅游业已经越来越大众化,而旅游业的核心是信息,不论是对旅游管理部门、对旅游企业,或是对旅游者而言,有效的获取旅游信息,都显得特别重要.旅游管理系统将使旅游相关信息管理工作规范化、信息化、程序化,提供旅游景点、旅游线路,旅游新闻等服务本文以jsp…

压力测试Monkey命令参数和报告分析

目录 常用参数 -p <测试的包名列表> -v 显示日志详细程度 -s 伪随机数生成器的种子值 --throttle < 毫秒> --ignore-crashes 忽略崩溃 --ignore-timeouts 忽略超时 --monitor-native-crashes 监视本地崩溃代码 --ignore-security-exceptions 忽略安全异常 …

如何使用ig507金融数据库的股票接口,股票API来获取MACD指标

一、MACD指标简介 MACD&#xff08;Moving Average Convergence Divergence&#xff0c;移动平均收敛/发散&#xff09;是一种趋势跟踪动量指标&#xff0c;用于分析股票或其他金融产品的价格趋势。MACD由两部分组成&#xff1a;差离值&#xff08;DIF&#xff09;和信号线&am…

借助ChatGPT降低学术论文重复率,使用技巧全攻略,实用有效,快速上手

大家好&#xff0c;感谢关注。我是七哥&#xff0c;一个在高校里不务正业&#xff0c;折腾学术科研AI实操的学术人。可以&#xff08;yida985&#xff09;交流学术写作或ChatGPT等AI领域相关问题&#xff0c;多多交流&#xff0c;相互成就&#xff0c;共同进步。 经常有学术同…

Python编程技巧:如何正确使用with语句(Python中with用法详解)

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 文章内容 📒📝 基本语法📝 处理文件📝 处理网络连接📝 管理线程锁📝 管理数据库连接📝 管理临时目录和文件📝 使用上下文装饰器📝 自定义上下文管理器🎯 示例1🎯 示例2📝 使用多个上下文管理器📝 上下…

Visual Studio开发环境搭建

原文&#xff1a;https://blog.c12th.cn/archives/25.html Visual Studio开发环境搭建 测试&#xff1a;笔记本原装操作系统&#xff1a;Windows 10 家庭中文版 资源分享链接&#xff1a;提取码&#xff1a;qbt2 注意事项&#xff1a;注意查看本地硬盘是否够用&#xff0c;建议…

UE5开发游戏Tutorial

文章目录 PlayerStart 初始化设置默认 LevelBP_Character 初始化BP_Character 添加动画BP_Character 攻击BP_Enemy 初始化 以及 AI 运动Camera Collision 相机碰撞BP_Character 生命以及伤害Wave Spawner 波生成UI 初始化以及 Damage Screen指定位置随机生成添加声音环境 Envir…

茴香豆的使用

RAG RAG 模型的核心在于两大部分&#xff1a;检索器&#xff08;Retriever&#xff09;和生成器&#xff08;Generator&#xff09;。检索器的作用是从一个庞大的数据集中&#xff0c;根据输入的问题或者提示&#xff0c;快速有效地检索出最相关的信息或文档。这一步骤通常利用…

【算法专题--链表】两两交换链表中的节点 -- 高频面试题(图文详解,小白一看就懂!!!)

目录 一、前言 二、题目描述 三、解题方法 ⭐双指针 -- 采用哨兵位头节点 &#x1f95d; 什么是哨兵位头节点&#xff1f; &#x1f34d; 解题思路 &#x1f34d; 案例图解 四、总结与提炼 五、共勉 一、前言 两两交换链表中的节点 这道题&#xff0c;可以说…