Mybatis-plus自动生成主键id存在的坑

本文记录了一次在使用Mybatis-plus框架进行数据库操作时遇到的ID自增溢出问题,详细介绍了问题的发现、排查及解决过程。通过调整实体类的注解配置,成功关闭了Mybatis-plus的自动生成ID功能,解决了ID长度超出数据库表定义长度的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、问题发现:今天写项目的时候由于需求变化,增加了实体表,创建实体后进行增删改查操作,结果插入数据的时候自动生成的id巨大,大概有这么大125413703487479810,id长度超出数据库表定义的长度,导致数据插不进去,手动插入数据又很正常,排查半天一直找不到问题所在。

二、问题解决过程:一开始总根据报错信息说id超出定义的长度去找解决方法,结果都是叫我去修改数据库。后面仔细想了一下,为什么那么多表都没事,单单这个新增的表有问题呢?于是把思路转到Mybatis-plus自动生成主键的方向上,最终证明是正确的。

三、原因:Mybatis-plus会自动生成一个长数字字符串作为主键

四、解决方法:

1.在实体类的id添加注解,关闭Mybatis-plus自动生成id就行了

@TableId(value = "id",type = IdType.AUTO)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值