添加了 @TableId(type = IdType.AUTO) 但仍生成超大 ID

紧急排查数据库表结构(核心,必须执行)

首先通过 SQL 验证dish_category表的id字段配置,这是问题的根源:

  1. 连接你的数据库,执行以下 SQL 查看完整表结构: sql

    复制代码
    -- 查看dish_category表的详细创建语句,重点关注id字段
    SHOW CREATE TABLE dish_category;
  1. 问题的核心元凶 :表结构末尾的AUTO_INCREMENT=2011257341079490564,表示数据库的自增序列当前起始值就是这个超大数字 ,后续新增数据时,ID 会从这个值开始连续递增(比如下一条就是2011257341079490565),自然还是超大 ID。
  2. **为什么初始值会这么大?**大概率是之前使用雪花算法插入过数据,或手动插入过超大 ID 值,导致数据库的自增序列被 "拉高",即使后续切换为数据库原生自增,也会从这个超大初始值继续递增,不会自动重置。

二、解决方案:重置自增序列初始值(一步到位解决超大 ID)

核心操作是AUTO_INCREMENT初始值重置为合理的数值,让后续新增数据的 ID 从连续小数字开始递增,具体分两种场景执行 SQL:

场景 1:表中无重要数据(或已备份,想从 1 开始递增)

直接将自增初始值重置为1,后续新增数据的 ID 从 1 开始连续排列:

sql

复制代码
-- 重置dish_category表的自增初始值为1
ALTER TABLE dish_category AUTO_INCREMENT = 1;
相关推荐
海奥华23 分钟前
mysql索引
数据库·mysql
程序员泠零澪回家种桔子31 分钟前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构
2601_949593651 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__1 小时前
mysql新老项目版本选择
数据库·mysql
Dxy12393102161 小时前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql
Dying.Light1 小时前
MySQL相关问题
数据库·mysql
蜡笔小炘2 小时前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长2 小时前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
晚霞的不甘2 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频
Re.不晚2 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构