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