写于20210618 21:00 北京望京
一条记录update一次,性能比较差,容易造成阻塞。基于 mybatis 批量更新,特此记录。
微信搜:JavaPub ,有疑惑留言。
@[toc]
1.场景
当我们在做更新或者是插入操作时,数据为多对多、一一对应的情况
例如:
1 | bash复制代码编号。 名字。 状态 |
代码中循环写入、更新这是大多数人做法,但是肯定不是最优解
2.MyBatis XML
- 先直接上个终极版
这里数据库中存储了下划线式,代码中用驼峰式。
这里是通过userId修改userStatus。当user_id为1时、user_status为0,当user_id为3时、user_status为1。
1 | xml复制代码 <update id="updateBatch"> |
<trim 属性说明
- prefix,suffix 表示在 trim 标签包裹的部分的前面或者后面添加内容
- 如果同时有 prefixOverrides,suffixOverrides 表示会用 prefix,suffix 覆盖 Overrides 中的内容。
- 如果只有 prefixOverrides,suffixOverrides 表示删除开头的或结尾的 xxxOverides 指定的内容。
2.1.打印sql
1 | bash复制代码==> Preparing: update `table_test_01` set user_status =case when user_id=? then ? when user_id=? then ? end where user_id in ( ? , ? ) |
2.2.数据库结构
SQL结构体:
1 | sql复制代码CREATE TABLE `table_test_01` |
1 | sql复制代码INSERT INTO `table_test_01` |
3.实例二
- 多个字段更新,那就增加
<item
。
使用 case when 语法。
1 | sql复制代码UPDATE course |
这条sql的意思是,如果id为1,则name的值为name1,title的值为New Title1;依此类推。
1 | xml复制代码 <update id="updateBatch1" parameterType="list"> |
4.重点
但是大家要注意一点,这种情况如果出错,我们并不知道是哪条错误,如果使用事务,就会全部回滚,好的办法就是一次批量一部分,分担出错概率。
我是JavaPub,我们下期见。
源码案例下载:download.csdn.net/download/qq…
参考:
blog.csdn.net/lu102418831…
blog.csdn.net/xyjawq1/art…
本文转载自: 掘金