验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

mybatis plus新增数据获取主键id的问题怎么解决

阅读:418 来源:乙速云 作者:代码code

mybatis plus新增数据获取主键id的问题怎么解决

      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。

    分享到:
    *特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
    相关文章
    {{ v.title }}
    {{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
    你可能感兴趣
    推荐阅读 更多>