人大金仓数据库sql 批量插入 预置的语句中不能插入多个命令 mybatis

人大金仓数据库与mysql和oracle还不同,与oracle里的函数很类似,嗯。

原因是下方的sql,在mysql和oracle是可以运行,在mysql里甚至可以把insert into写在循环的外面。
但是在人大金仓数据库里这么写的话,就会报错:### Error updating database. Cause: java.sql.SQLException: get ParameterMetaData Error:java.sql.SQLException: [KingbaseES Server]ERROR: 预置的语句中不能插入多个命令

<insert id="insertBrokersList" parameterType="java.util.List">
        <foreach collection="list" item="item" index="index" separator=";">
            INSERT INTO T_FOREIGN_BROKERS
            ("PLAYER_NAME","IS_DEL","CREATE_TIME","UPDATE_TIME" )
            VALUES
            (#{item.brokersName},0,now(),now())
        </foreach>
    </insert>

改为下面这种方式即可:

<insert id="insertBrokersList" parameterType="java.util.List">
        INSERT INTO T_FOREIGN_BROKERS
        ("PLAYER_NAME","IS_DEL","CREATE_TIME","UPDATE_TIME" )
        <foreach collection="list" item="item" index="index" separator="UNION ALL">
            SELECT
            to_char(#{item.brokersName}),0,now(),now() FROM DUAL
        </foreach>
    </insert>

需要注意的是 separator=”UNION ALL” ,和 to_char()函数,明确字符串类型.
数据库语句格式:
这里写图片描述
终于实现了!thanks luhan

ps:所有的时间类型也要用to_char转换,不然时间会被莫名的力量修改掉。。。。

猜你喜欢

转载自blog.csdn.net/bc_aptx4869/article/details/80611467
今日推荐