Unable to make batch insert into Oracle DB using MyBatis(无法使用MyBatis将批处理插入Oracle DB)
本文介绍了无法使用MyBatis将批处理插入Oracle DB的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
尝试使用MyBatis(与Spring集成)批量插入Oracle数据库中的表。
这是映射器接口中方法的定义:
public void savePayments(@Param("payments") List<MassPaymentItem> payments);
这是MyBatis XML映射器代码:
<insert id="savePayments" parameterType="MassPaymentFileItem" useGeneratedKeys="false">
INSERT INTO mass_payments
(payment_id, file_id, msisdn, amount, status)
<foreach collection="payments" item="payment" index="index" separator=" UNION ALL ">
SELECT SEQ_MASS_PAYMENT.nextval, #{payment.fileId}, #{payment.msisdn}, #{payment.amount}, 0 FROM DUAL
</foreach>
</insert>
当我执行此操作时,收到MyBatiSystemException,并显示消息"嵌套异常是org.apache.ibati.Builder.BuilderException:不正确的内联参数映射格式。应为:#{p.Name,attr1=val1,attr2=val2}"
出了什么问题?如何修复它?
推荐答案
我找到解决方案here
<insert id="savePayments">
INSERT ALL
<foreach collection="payments" item="payment">
INTO
mass_payments_t (payment_id, file_id, msisdn, amount)
VALUES
(seq_mass_payment.nextval, #{payment.fileId, javaType=Integer, jdbcType=NUMERIC}, #{payment.msisdn, javaType=String, jdbcType=VARCHAR}, #{payment.amount, javaType=BigDecimal, jdbcType=NUMERIC})
</foreach>
SELECT * FROM dual
</insert>
这篇关于无法使用MyBatis将批处理插入Oracle DB的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:无法使用MyBatis将批处理插入Oracle DB
猜你喜欢
- 如何指定 CORS 的响应标头? 2022-01-01
- 如何使 JFrame 背景和 JPanel 透明且仅显示图像 2022-01-01
- 未找到/usr/local/lib 中的库 2022-01-01
- Eclipse 的最佳 XML 编辑器 2022-01-01
- GC_FOR_ALLOC 是否更“严重"?在调查内存使用情况时? 2022-01-01
- 将 Java Swing 桌面应用程序国际化的最佳实践是什么? 2022-01-01
- 在 Java 中,如何将 String 转换为 char 或将 char 转换 2022-01-01
- 获取数字的最后一位 2022-01-01
- 转换 ldap 日期 2022-01-01
- java.lang.IllegalStateException:Bean 名称“类别"的 BindingResult 和普通目标对象都不能用作请求属性 2022-01-01