温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2023-03-06 16:14:12 来源:亿速云 阅读:151 作者:iii 栏目:开发技术

这篇文章主要介绍了mybatis plus新增数据获取主键id的问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇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。

    关于“mybatis plus新增数据获取主键id的问题怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“mybatis plus新增数据获取主键id的问题怎么解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI