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

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
人大金仓数据库一个功能强大的关系型数据库管理系统,提供了一个直观友好的SQL语句界面,方便用户进行数据查询、插入、更新和删除等操作。 在人大金仓数据库SQL语句界面,用户可以通过输入SQL语句来对数据库的数据进行操作。用户可以使用各种SQL语句,如SELECT、INSERT、UPDATE和DELETE等来实现不同的功能。 例如,如果用户想要查询数据库的某个表的数据,可以使用SELECT语句。用户只需要在SQL语句界面输入类似于“SELECT * FROM 表名”这样的SQL语句,即可获取该表的所有数据。 如果用户想要向数据库的某个表插入新的数据,可以使用INSERT语句。用户只需要在SQL语句界面输入类似于“INSERT INTO 表名 (列1, 列2, 列3) VALUES (值1, 值2, 值3)”这样的SQL语句,即可将指定的值插入到相应的列。 如果用户想要更新数据库的某个表的数据,可以使用UPDATE语句。用户只需要在SQL语句界面输入类似于“UPDATE 表名 SET 列1=新值1, 列2=新值2 WHERE 条件”这样的SQL语句,即可更新满足条件的数据。 如果用户想要删除数据库的某个表的数据,可以使用DELETE语句。用户只需要在SQL语句界面输入类似于“DELETE FROM 表名 WHERE 条件”这样的SQL语句,即可删除满足条件的数据。 总之,人大金仓数据库SQL语句界面提供了一个方便快捷的方式来操作数据库,用户只需要输入相应的SQL语句即可完成各种数据库操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值