本文介紹了無法使用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的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,