<foreach collection="list" item="item" index="index" open="(" close=")" separator="union all">
select
#{item.orderId,jdbcType=NUMERIC}, #{item.transactionId,jdbcType=VARCHAR}, #{item.orderType,jdbcType=
NUMERIC},
#{item.wxAppid,jdbcType=VARCHAR}, #{item.payOrderId,jdbcType=VARCHAR}, #{item.payTime,jdbcType=
DATE},
#{item.refundMoney,jdbcType=DECIMAL}, #{item.payState,jdbcType=NUMERIC}, #{item.source,jdbcType=
NUMERIC},
#{item.subMchId,jdbcType=VARCHAR}, #{item.plateNum,jdbcType=VARCHAR}, #{item.cardNo,jdbcType=
VARCHAR},
#{item.payType,jdbcType=NUMERIC}, #{item.payMoney,jdbcType=DECIMAL}, #{item.iden,jdbcType=
VARCHAR},
#{item.wxMchId,jdbcType=VARCHAR}, #{item.realPayMoney,jdbcType=DECIMAL}, #{item.id,jdbcType=
VARCHAR},
#{item.orderDate,jdbcType=DATE}, #{item.refundDate,jdbcType=DATE}, #{item.attach,jdbcType=
VARCHAR},
#{item.createTime,jdbcType=DATE}, #{item.updateTime,jdbcType=
DATE}
from dual
</foreach>
</insert>
运行通过。在Oracle的版本中,有几点需要注意的:
1.SQL中没有VALUES;
2.<foreach>标签中的(select ..... from dual);
3.<foreach>标签中的separator的属性为"UNION ALL",将查询合并结果集。
4.最重要的一点就是一定要在insert标签中加入useGeneratedKeys="false",如果不加则会报如下错误:
### Cause: java.sql.SQLSyntaxErrorException: ORA-00933: SQL 命令未正确结束
说明:insert的主键,我先调用了序列,然后复制给对象的属性了,所以在insert的时候直接用#{} 取字段就可以了
原文链接:https://blog.csdn.net/qq_37630354/article/details/82792288
mybatis使用oracle批量插入
标签:sele art except 结果 order 没有 版本 lin mybatis