美文网首页
2021-10-18-MyBatis Oracle 批量插入数据

2021-10-18-MyBatis Oracle 批量插入数据

作者: 一_贫 | 来源:发表于2021-10-18 17:39 被阅读0次

原文

<insert id="addList" parameterType="java.util.List" useGeneratedKeys="false">
        INSERT ALL
        <foreach item="item" index="index" collection="list">
        INTO T_APPLAUD
        (
            ID,
            USER_ID,
            BUSINESS_TYPE,
            PRODUCT_ID,
            CREATE_TIME
        ) VALUES
        (
            #{item.id, jdbcType=NUMERIC},
            #{item.userId, jdbcType=VARCHAR},
            #{item.businessType, jdbcType=VARCHAR},
            #{item.productId, jdbcType=VARCHAR},
            #{item.createdTime, jdbcType=NUMERIC} 
        )
        </foreach>
        SELECT 1 FROM DUAL
    </insert>
<insert id="addList" parameterType="java.util.List" useGeneratedKeys="false">
        INSERT INTO T_APPLAUD
        (
            ID,
            USER_ID,
            BUSINESS_TYPE,
            PRODUCT_ID,
            CREATE_TIME
        )
        <foreach item="item" index="index" collection="list" separator="union all">
        (
            SELECT 
                #{item.id},
                #{item.userId},
                #{item.businessType},
                #{item.productId},
                #{item.createdTime} 
            FROM DUAL
        )
        </foreach>
    </insert>

两种方式更推荐使用第二种方式
但是在使用的过程中又遇到了新的问题,当插入的数据超过 4000 条的时候,mybatis 执行的时候报错:

ORA-01745:无效的主机/绑定变量名
分析判断是因为 union all 插入 sql 太长,导致程序解析 SQL 出错。

相关文章

网友评论

      本文标题:2021-10-18-MyBatis Oracle 批量插入数据

      本文链接:https://www.haomeiwen.com/subject/dxunoltx.html