DB2用mybatis批量update的问题

Posted

tags:

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

这是Test.java里测试用的代码
ApplicationContext ac = new ClassPathXmlApplicationContext("spring-mybatis.xml");
JobNodeLnkMapper mapper = ac.getBean("jobNodeLnkMapper", JobNodeLnkMapper.class);
JobNodeLnk[] jobNodeLnks = new JobNodeLnk[5];
JobNodeLnk lnk = null;
for (int i = 0; i < 5; i++)
lnk = new JobNodeLnkImpl(Long.parseLong(String.valueOf(62+i)),Long.parseLong(String.valueOf((i+5))),Long.parseLong(String.valueOf((i+5))));
jobNodeLnks[i] = lnk;

for (int i = 0; i < 5; i++)
System.out.println(jobNodeLnks[i].toString());

System.out.println(mapper.updateJobNodeLnks(jobNodeLnks));
这是Mapper.xml里的语句
<update id="updateJobNodeLnks" parameterType="dayu.dmc.bean.impl.JobNodeLnkImpl">
<foreach collection="array" item="item">
update ysbase_dmc_jobNodeLnk set nodeid=#item.nodeId where id=#item.id;
</foreach>
</update>
### The error occurred while setting parameters

### SQL: update ysbase_dmc_jobNodeLnk set nodeid=? where id=?;update ysbase_dmc_jobNodeLnk set nodeid=? where id=?;update ysbase_dmc_jobNodeLnk set nodeid=? where id=?;update ysbase_dmc_jobNodeLnk set nodeid=? where id=?;update ysbase_dmc_jobNodeLnk set nodeid=? where id=?
### Cause: com.ibm.db2.jcc.am.SqlSyntaxErrorException: DB2 SQL Error: SQLCODE=-104, SQLSTATE=42601, SQLERRMC=update YSBASE_DMC_JOBNODELNK set NODEID=? w;BEGIN-OF-STATEMENT;<space>, DRIVER=4.16.53
; bad SQL grammar []; nested exception is com.ibm.db2.jcc.am.SqlSyntaxErrorException: DB2 SQL Error: SQLCODE=-104, SQLSTATE=42601, SQLERRMC=update YSBASE_DMC_JOBNODELNK set NODEID=? w;BEGIN-OF-STATEMENT;<space>, DRIVER=4.16.53

参考技术A mysql没有提供直接的方法来实现批量,但可以使用case when语法来实现这个功能。
UPDATE course
SET name = CASE id
WHEN 1 THEN 'name1'
WHEN 2 THEN 'name2'
WHEN 3 THEN 'name3'
END,
title = CASE id
WHEN 1 THEN 'New Title 1'
WHEN 2 THEN 'New Title 2'
WHEN 3 THEN 'New Title 3'
END
WHERE id IN (1,2,3)本回答被提问者采纳

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用mybatis批量update的问题的主要内容,如果未能解决你的问题,请参考以下文章

最近用MyBatis做开发的时候发现,MyBatis有个小小的缺点,不支持批量update?

DB2批量update问题

mybatis 批量执行多条update语句

mybatis如何对db2数据库进行批量修改操作

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

on duplicate key update 的用法说明(解决批量操作数据,有就更新,没有就新增)mybatis批量操作数据更新和添加