mybatis plus新增(insert)数据获取主键id的问题
作者:Rookie_cc 时间:2023-08-09 10:50:52
mybatis plus新增(insert)数据获取主键id
在我们执行insert操作的时候,往往会需要拿到新插入数据的主键id做下一步操作。
例:
//新增银行卡
BankCard bankCard = new BankCard();
bankCard.setBankCardRealName(bankCardRequest.getRealName());
bankCard.setBankCardNum(bankCardRequest.getBankCardNum());
bankCard.setBankName(bankCardRequest.getBankName());
int index = bankCardMapper.insert(bankCard);
这里insert之后返回的index实际是你增加的数据列数,并不是主键id。
要想获取主键id,只需要在insert之后直接get该对象的主键id即可
例:
//新增银行卡
BankCard bankCard = new BankCard();
bankCard.setBankCardRealName(bankCardRequest.getRealName());
bankCard.setBankCardNum(bankCardRequest.getBankCardNum());
bankCard.setBankName(bankCardRequest.getBankName());
bankCardMapper.insert(bankCard);
Long id = bankCard.getId();
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都是没问题的,突然出现这个,也是很困惑
出现这个问题的原因,还是因为自己技术不熟练啦~~
来源:https://blog.csdn.net/Rookie_cc/article/details/106664347
标签:mybatis,plus,insert,主键id
0
投稿
猜你喜欢
C#实体对象序列化成Json并让字段的首字母小写的两种解决方法
2023-02-24 18:41:44
聊一聊jdk1.8中的ArrayList 底层数组是如何扩容的
2023-11-16 08:55:50
C#中Convert.ToDecimal()报错问题的解决
2022-05-09 06:05:56
Android中GridView布局实现整体居中方法示例
2023-12-23 13:21:18
关于Springboot中JSCH的使用及说明
2023-11-28 02:32:16
Java设计模式之命令模式_动力节点Java学院整理
2023-12-11 13:32:03
JavaWeb如何实现禁用浏览器缓存
2021-09-13 01:27:45
C#中的WebRequest与WebResponse抽象类、DNS静态类、Ping类介绍
2022-12-28 05:22:15
关于springboot 配置文件中属性变量引用方式@@解析
2023-12-08 21:50:03
SpringBoot整合Shiro的代码详解
2023-10-30 10:53:31
Java后端Cookie实现(时间戳)代码实例
2022-05-17 09:39:52
聊聊MultipartFile与File的一些事儿
2023-06-27 03:07:00
Android自定义View实现课程表表格
2023-03-11 19:33:08
C#函数out多个返回值问题
2022-11-14 21:58:55
java使用RandomAccessFile类基于指针读写文件实例代码
2021-07-29 17:45:45
SpringBoot整合Thymeleaf小项目及详细流程
2021-08-13 16:32:08
MyBatis执行动态SQL的方法
2021-05-29 04:02:17
解决java.util.NoSuchElementException异常的问题
2023-02-10 08:26:46
Android ListView实现仿iPhone实现左滑删除按钮的简单实例
2023-06-15 04:25:59
巧用Spring中的@Order进行排序
2023-07-13 05:53:48