mybatis plus新增(insert)数据获取主键id的问题
作者:Rookie_cc
这篇文章主要介绍了mybatis plus新增(insert)数据获取主键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。
也是很奇怪为什么之前的那部分数据的自增ID都是没问题的,突然出现这个,也是很困惑
出现这个问题的原因,还是因为自己技术不熟练啦~~
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。