DB2批量update问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DB2批量update问题相关的知识,希望对你有一定的参考价值。

update A set a = (SELECT B.a FROM B WHERE B.b = A.b AND B.c = A.c)
报返回结果为多行,求修改为可以批量改A表a栏位的sql,要求纯SQL实现

原因是 UPDATE SET 一个结果集时要求该结果集必须只有一行值, 但 SELECT B.a FROM B WHERE B.b = A.b AND B.c = A.c 该结果集在对应到A表update时出现了多行值.
改为(如有多行值,则取多个值中的第一行):
update a A set a = (SELECT B.a FROM B WHERE B.b = A.b AND B.c = A.c

fetch first 1 rows only )
参考技术A update A set A.a=B.a from A left join B on A.b=B.b and A.c=B.c
where 条件区间
参考技术B 这是db2 的批量更新,需要用到exists
update A set a = (SELECT B.a FROM B WHERE B.b = A.b AND B.c = A.c) where exists(SELECT B.a FROM B WHERE B.b = A.b AND B.c = A.c)

mybatis批量update操作的写法,及批量update报错的问题解决方法

mybatis的批量update操作写法很简单,如下:

public interface YourMapper extends BaseMapper<YourExt> {

    void updateBatch(@Param("pojos") Collection<YourExt> pojos);
}
  <update id="updateBatch" parameterType="java.util.Collection">
        <foreach collection="pojos" item = "pojo" separator= ";" >
            update your_table t set pt.your_value = #{pojo.yourValue} where pt.id = #{pojo.id}
        </foreach>
    </update>

在执行过程中报异常,但是sql和参数直接在DB里执行是好的,原因是MySql默认不支持批量更新,需要开发人员主动设置,只需要在你的数据库连接url后面加上

&allowMultiQueries=true
就好了
技术分享图片

例如我的数据库连接配置就会变成

以上是关于DB2批量update问题的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Apache Apex 将数据从 DB2 批量摄取到 Vertica

sh DB2的批量授予权限

sh DB2的批量授予权限

db2 - 在不同的表上使用 select 更新批量行

mybatis批量update操作的写法,及批量update报错的问题解决方法

MySQL的更新语句update中可以用子查询吗?