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
  • asp之家 软件编程 m.aspxhome.com