我尝试使用MyBatis(与Spring集成)批量插入Oracle数据库的表。
这是mapper接口(interface)中方法的定义:
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>
当我执行此操作时,我收到 MyBatisSystemException 并显示消息“嵌套异常是 org.apache.ibatis.builder.BuilderException:不正确的内联参数映射格式。应该是:#{propName,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>
关于java - 无法使用 MyBatis 批量插入 Oracle DB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26278531/