99网
您的当前位置:首页mybatis-plus坑之insert方法

mybatis-plus坑之insert方法

来源:99网
mybatis-plus坑之insert⽅法

写在前⾯

有天早上我的⼀个同事,突然跑来告诉我。我们某张表的⾃增ID变得很⼤。类似1173776258468638722 这种。这个当然是不能接受的啊。

着⼿解决

然后就开始找问题的原因,⼀开始我想的是数据库上的问题,我删掉不合理的数据,

alter table *** AUTO_INCREMENT=20,修改⾃增ID从20开始。⼿动插⼊数据,居然OK。

那就说明,可能是我们代码insert数据的时候存在的问题。我找到数据库访问层的insert语句处,发现使⽤的是mybatis-plus,⽹上查了⼀下关于这块的东西,发现insert⽅法在配置的时候,可以指定⾃增ID的⽅式。源码中定义有以下⼏种:

public enum IdType {

AUTO(0, \"数据库ID⾃增\"), INPUT(1, \"⽤户输⼊ID\"),

ID_WORKER(2, \"全局唯⼀ID\"), UUID(3, \"全局唯⼀ID\"),

NONE(4, \"该类型为未设置主键类型\"),

ID_WORKER_STR(5, \"字符串全局唯⼀ID\");

然后我就果断⼿动配置了⼀下,

@TableId(type = IdType.AUTO) private Long userId;

,重启测试,OK。

也是很奇怪为什么之前的那部分数据的⾃增ID都是没问题的,突然出现这个,也是很困惑总结,出现这个问题的原因,还是因为⾃⼰技术不熟练啦~~

因篇幅问题不能全部显示,请点此查看更多更全内容