• MyBatis批量插入


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

    代码写的很漂亮,但是效果却没有出现,直接报错:

    java.sql.SQLException: ORA-00933: SQL 命令未正确结束
    

    查阅相关资料才知道,Oracle没有这种语法。MySql对上述语法支持。所以需要将SQL做如下修改

    <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>




  • 相关阅读:
    计算机考研复试真题 数字求和
    计算机考研复试真题 简单计算器
    计算机考研复试真题 N阶楼梯上楼问题
    P1082 [NOIP2012 提高组] 同余方程
    进制转换
    浮点数加法
    N的阶乘
    1055 The World's Richest (25 分)
    1028 List Sorting (25 分)
    1062 Talent and Virtue (25 分)
  • 原文地址:https://www.cnblogs.com/longxok/p/10868372.html
Copyright © 2020-2023  润新知