人大金仓数据库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转换,不然时间会被莫名的力量修改掉。。。。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值