Mybatis批量插入并返回主键id的方法

网友投稿 376 2022-08-17


Mybatis批量插入并返回主键id的方法

目录场景错误分析原因排查问题

场景

在做商城的时候,sku表进行了拆分,sku的基本信息以及sku的库存表。因为库存会经常的变动,会导致行锁。

这里就是新增的时候,因为在新增商品的时候,会有多条sku的数据进行批量的插入,那么有批量插入sku基本信息以及批量插入sku的库存信息。

其中,就需要批量插入sku的基本信息的时候,返回主键id,这就能够在sku批量插入库存信息的时候能够插入skuId;

错误

nested exception is org.apache.ibatis.executor.ExecutorException: Error getting generated key or setting result to parameter object. Cause: org.apache.ibatis.execXfSoLutor.ExecutorException: Could not determine which parameter to assign generated keys to. Note that when there are multiple parameters, 'keyProperty' must include the parameter name (e.g. 'id'). Specified key properties are [id] and available parameters are [XXX, XXX, param1, param2]

分析原因

数据库是否支持自动生成密钥字段(例如mysql和SQL Server),那么就只需设置useGeneratedKeys=“true” 并将 keyProperty设置为java对象的属性名,keyColumn是数据库中的列名(当主键列不是表中的第一列的时候,它必须设置的) 。传参有多个个参数,mybatis并不知道keyProperty = "id"中的 id 赋值给谁(我就是这里出错)我看其他的博客还有说是版本的问题,建议3.3.1以上的。

排查问题

数据库是MySQL,设置了 useGeneratedKeys=“true” ,且 keyProperty = id是Java对象的属性名,id是主键列且在第一列中

就是这里出错,keyProperty=“id”,导致不知道id返回到哪一个参数中

原来:

insert into goods_sku (goods_id,images,indexes,spec,price,size,bkge_scale,team_scale,direct_scale,enable,create_time,update_time) values

(#{param2},#{item.images},#{item.indexes},#{item.spec},#{item.price},#{item.size},#{item.bkgeScale},#{item.teamScale},#{item.directScale},#{item.enable},#{param3},#{param3})

进行修改:

insert into goods_sku

(goods_id,images,indexes,spec,price,size,bkge_scale,team_scale,direct_scale,enable,create_time,update_time) values

(#{param2},#{item.images},#{item.indexes},#{item.spec},#{item.price},#{item.size},#{item.bkgeScale},#{item.teamScale},#{item.directScale},#{item.enable},#{param3},#{param3})

依赖版本:

附上完整的Mapperhttp://以及Xml文件

GoodsSkuMapper.java

int insertBatch(@Param("goodsSkuDTOs") List goodsSkuDTOs, @Param("goodsId") Long goodsId,@Param("date") Date date);

GoodsSkuMapper.xml

insert into goods_sku (goods_id,images,indexes,spec,price,size,bkge_scale,team_scale,direct_scale,enable,create_time,update_time) values

(#{param2},#{item.images},#{item.indexes},#{item.spec},#{item.price},#{item.size},#{item.bkgeScale},#{item.teamScale},#{item.directScale},#{item.enable},#{param3},#{param3})


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:springboot 如何解决yml没有spring的小叶子标志问题
下一篇:详解JUC并发编程中的进程与线程学习
相关文章

 发表评论

暂时没有评论,来抢沙发吧~