mabatis的批量新增sql 初级的 初级的 初级的

本文介绍了一种使用MyBatis框架批量插入数据到数据库的方法。通过使用foreach循环遍历List集合,实现了高效的数据批量插入操作,并提供了具体的代码实现及SQL映射示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单描述:做开发的时候,会遇到一次插入好多条记录,怎么做好呢?

解决思路:循环insert啊!  哪凉快那呆着去←!←  这样会增加数据库开销的,当然不能这么干了,要在sql上下功夫。看代码,一下就明白了

代码

private void saveRoleOrgRes(String resIds,OhSysPriRoleOrgVo roleOrgVo) throws Exception {  //service层代码
if(Tools.notEmpty(resIds)){
List<OhSysPriRoleOrg> list = new ArrayList<>();
String[] resIdArr = resIds.split(","); //剪切id字符串
for (String resId: resIdArr) {
OhSysPriRoleOrg roleOrg = new OhSysPriRoleOrg();
roleOrg.setRoleOrgId(UuidUtil.get32UUID());
roleOrg.setOrgId(roleOrgVo.getOrgId());
roleOrg.setResId(resId); //为每个对象的id赋值
roleOrg.setRoleId(roleOrgVo.getRoleId());
roleOrg.setPriOrgLevel(roleOrgVo.getOrgLevel());
list.add(roleOrg);
}
dao.save("XXXXRoleOrgMapper.insert",list);
}
}
mapper的sql:
<insert id="insert" parameterType="java.util.List">
insert into <include refid="tableName"></include>
(
<include refid="Field"></include>
) values
<foreach collection="list" item="item" index="index" separator=",">
(
<include refid="FieldValue"></include>
)  
</foreach>
</insert>

 <sql id="FieldValue">  
#{item.xxxOrgId},
#{item.xxxId},
#{item.xxId},
#{item.xxxLevel},
#{item.xxxParentId}
</sql>

总结:这就是sql语法灵活运用的表现啦,对list中的每个对象加上foreach循环,但是 要特别的注意,映射取值的时候里边一定要放item,否则的话会mybatis绑定异常

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'xxxId' not found.Available parameters are [ xxxId ,list ]。

转载于:https://www.cnblogs.com/xuchao0506/p/9578077.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值