mybatis插入多条记录

本文介绍了一种在Oracle数据库中批量插入数据的有效方法。通过使用insert all into...values语句结合mybatis框架,解决了批量保存数据时出现的SQL错误问题。

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

今天遇到一个批量保存数据的问题,很自然的想到了使用insert into values(),()…这种方式保存数据,于是在mybatis配置文件中使用如下配置:

<insert id="saveBatch" parameterType="java.util.List">
     insert into T_PA_DATE (FID, FDATE_VALUE, FSELECTED, 
      FDELETED)
    values 
    <foreach collection="list" item="date" separator=",">
        (#{date.id,jdbcType=DECIMAL}, #{date.dateValue,jdbcType=TIMESTAMP}, #{date.selected,jdbcType=DECIMAL}, 
      #{date.deleted,jdbcType=DECIMAL})
    </foreach>
  </insert>

结果不能sql报错:未正确结束命令行。
注意:本人使用的是oracle数据库,这种方式在mysql数据库上指令没有问题。
于是又想到了一跳:inset all into values() into tablename values() ,于是在mybatis中使用如下配置:

<insert id="saveBatch" parameterType="java.util.List">
     insert all into T_PA_DATE (FID, FDATE_VALUE, FSELECTED, 
      FDELETED)
    values 
    <foreach collection="list" item="date" separator="into T_PA_DATE values">
        (#{date.id,jdbcType=DECIMAL}, #{date.dateValue,jdbcType=TIMESTAMP}, #{date.selected,jdbcType=DECIMAL}, 
      #{date.deleted,jdbcType=DECIMAL})
    </foreach>
    select 1 from dual
  </insert>

执行成功。
说明:
1.最后跟的selecr 1 from dual语句中的dual表可以被替换为任何一个只要不是T_PA_DATE 的表
2.Oralce 9i以上版本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值