一、问题发现:今天写项目的时候由于需求变化,增加了实体表,创建实体后进行增删改查操作,结果插入数据的时候自动生成的id巨大,大概有这么大125413703487479810,id长度超出数据库表定义的长度,导致数据插不进去,手动插入数据又很正常,排查半天一直找不到问题所在。
二、问题解决过程:一开始总根据报错信息说id超出定义的长度去找解决方法,结果都是叫我去修改数据库。后面仔细想了一下,为什么那么多表都没事,单单这个新增的表有问题呢?于是把思路转到Mybatis-plus自动生成主键的方向上,最终证明是正确的。
三、原因:Mybatis-plus会自动生成一个长数字字符串作为主键
四、解决方法:
1.在实体类的id添加注解,关闭Mybatis-plus自动生成id就行了
@TableId(value = "id",type = IdType.AUTO)
本文记录了一次在使用Mybatis-plus框架进行数据库操作时遇到的ID自增溢出问题,详细介绍了问题的发现、排查及解决过程。通过调整实体类的注解配置,成功关闭了Mybatis-plus的自动生成ID功能,解决了ID长度超出数据库表定义长度的问题。
762

被折叠的 条评论
为什么被折叠?



