mysql批量更新的两种方式效率试验<二>
Mysql两种批量更新的对比
简介:
mysql搭载mybits框架批量更新有两种方式,一种是在xml中循环整个update语句,中间以‘;’隔开,还有一种是使用case when 变相实现批量更新,现就两种方法的效率做以对比。
两种写法:
方法一:整体循环update语句
注意:mysql默认不支持一条预编译sql以 ’; ’ 分割这种方式执行,需要在mysql 的jdbcUrl参数上追加 allowMultiQueries=true开启支持
SQL如下:
<!-- 批量更新表整体循环update语句-->
<update id="updateByForech" parameterType="java.util.List">
<foreach collection="list" item="item" >
update t_user
<set>
<if test="item.tName != null and item.tName != ''">
t_name = #{item.tName,jdbcType=VARCHAR},
</if>
<if test="item.tAge != null">
t_age = #{item.tAge},
</if>
<if test="item.tAddress != null">
t_address = #{item.tAddress,jdbcType=VARCHAR},
</if>
<if test="item.tPwd!= null">
t_pwd = #{item.tPwd,jdbcType=VARCHAR},
</if>
</set>
where t_id = #{item.tId};
</foreach>
</update>
该方法编写简单,便于理解,但是需要修改系统参数。
方法二:使用case when 方式拼接
SQL如下:
<!--caseWhen更新-->
<update id="updateByCaseWhen" parameterType="java.util.List">
update t_user
<trim prefix="set" suffixOverrides=",">
<trim prefix="t_name =case" suffix="end,">
<foreach collection="list" item="item">
<if test="item.tName !=null and item.tName != ''">
when t_id=#{item.tId} then #{item.tName,jdbcType=VARCHAR}
</if>
</foreach>
</trim>
<trim prefix="t_address =case" suffix="end,">
<foreach collection="list" item="item">
<if test="item.tAddress != null and item.tAddress != ''">
when t_id=#{item.tId} then #{item.tAddress,jdbcType=VARCHAR}
</if>
</foreach>
</trim>
<trim prefix="t_age =case" suffix="end,">
<foreach collection="list" item="item">
<if test="item.tAge != null">
when t_id=#{item.tId} then #{item.tAge}
</if>
</foreach>
</trim>
<trim prefix="t_pwd =case" suffix="end,">
<foreach collection="list" item="item">
<if test="item.tPwd != null">
when t_id=#{item.tId} then #{item.tPwd}
</if>
</foreach>
</trim>
</trim>
where t_id in
<foreach collection="list" item="item" separator="," open="(" close=")">
#{item.tId}
</foreach>
</update>
该方法sql 拼接复杂,为每一个要更新的字段罗列出id值,若数据出现问题,定位困难。
效率统计:
- 批量更新10条数据两种方法用时统计:
时间可以忽略不计;
- 批量更新100条数据两种方法用时统计:
- 批量更新1000条数据两种方法用时统计:
- 批量更新5000条数据两种方法用时统计:
- 批量更新10000条数据两种方法用时统计:
总结:
1.一次修改数据量较小的情况下, case when方式 和 整体更新方式 均可选择,但是整体更新需要新增系统参数配置
2.对于经常出现数据问题的,建议使用整体循环update方式,该方式生sql就是简单的update语句的拼接,便于定位问题。而case when方式 会在每一个需要修改的参数后面罗列出主键,切在mapper文件中出现大量冗余。
3.对于批量更新数据量很大的情况,case when效率低下,建议使用整体循环update。
该项目源码地址:https://git.lug.ustc.edu.cn/zhaiyt/demo7.git
mysql批量更新的两种方式效率试验<二>的更多相关文章
- mysql级联更新的两种方式:触发器更新和外键
1.mysql级联更新有两种方式:触发器更新和外键更新. 2.触发器更新和外键更新的目的都是为了保证数据完整性. 我们通常有这样的需求:删除表Table 1中记录,需要同时删除其它表中与Table 1 ...
- Mysql批量更新的三种方式
前言 批量插入由于mysql的VALUES原生支持,使用较为便利. 批量更新的写法一般有三种,在更新数量较少的情况下,前两种性能不相上下.但是在更新字段增加,更新条数较多(500以上)建议使用第三种写 ...
- c#mysql批量更新的两种方法
总体而言update 更新上传速度还是慢. 1: 简单的insert 速度稍稍比MySqlDataAdapter慢一点 配合dapper 配置文件 <?xml version="1 ...
- mybatis学习之路----批量更新数据两种方法效率对比
原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...
- mybatis批量保存的两种方式(高效插入)
知识点:mybatis中,批量保存的两种方式 1.使用mybatis foreach标签 2.mybatis ExecutorType.BATCH 参考博客:https://www.jb51.net/ ...
- mybatis中批量插入的两种方式(高效插入)
MyBatis简介 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用 ...
- mysql复制表的两种方式
mysql复制表的两种方式. 第一.只复制表结构到新表 create table 新表 select * from 旧表 where 1=2 或者 create table 新表 like 旧表 第二 ...
- 自学Linux Shell9.4-基于Red Hat系统工具包存在两种方式之二:源码包
点击返回 自学Linux命令行与Shell脚本之路 9.4-基于Red Hat系统工具包存在两种方式之二:源码包 本节主要介绍基于Red Had的系统(测试系统centos) 1. 工具包存在两种方式 ...
- Oracle并行更新的两种方式(merge/update内联视图)
对于Oracle的两表联合更新的场景(有A.B两表,以A.id=B.id关联,根据B表中的记录更新A表中的相应字段),一般有update内联视图和merge两种方式,下面举例介绍: 创建用例表: ...
随机推荐
- 关于Mysql表InnoDB下插入速度慢的解决方案
最近做了 server_log 日志数据库记录,仅仅插入,由平台来获取数据进行分析的需求. 但是内部反馈插入数据库记录非常耗时,我就很纳闷了,一个insert怎么会 30-50ms 呢?按说应该在 0 ...
- Apache Kafka 快速入门
概述 Apache Kafka是一个分布式发布-订阅消息系统和强大的队列,可以处理大量的数据,将消息从一个端点传递到另一个端点.Kafka适合离线和在线消息消费,Kafka消息保存在磁盘上,并在集群内 ...
- kettle 6.1 日志查询
SELECT JB.ID_JOB, ---作业ID JB.NAME, ---作业名称 to_char(JB.DESCRIPTION) as JOB_DESCRIPTION , --作业描述 case ...
- SSE图像算法优化系列九:灵活运用SIMD指令16倍提升Sobel边缘检测的速度(4000*3000的24位图像时间由480ms降低到30ms)。
这半年多时间,基本都在折腾一些基本的优化,有很多都是十几年前的技术了,从随大流的角度来考虑,研究这些东西在很多人看来是浪费时间了,即不能赚钱,也对工作能力提升无啥帮助.可我觉得人类所谓的幸福,可以分为 ...
- maven scope 范围讲解
解决办法: <dependency> <groupId>javax.servlet</groupId> <artifactId>java ...
- 正则双重过滤 /// splitKey1 第一个正则式匹配 /// splitKey2 匹配结果中再次匹配进行替
/// <summary> /// 正则双重过滤 /// splitKey1 第一个正则式匹配 /// splitKey2 匹配结果中再次匹配进行替换 /// </summary&g ...
- 【Linux】磁盘读写 测试
一.如何查看当前磁盘的IO使用情况 使用命令:iotop Total DISK READ: 3.89 K/s | Total DISK WRITE: 0.00 B/s TID PRIO USER DI ...
- css实现高度或者宽度不固定的div元素垂直左右居中
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 强化学习-Q-Learning算法
1. 前言 Q-Learning算法也是时序差分算法的一种,和我们前面介绍的SARAS不同的是,SARSA算法遵从了交互序列,根据当前的真实行动进行价值估计:Q-Learning算法没有遵循交互序列, ...
- [转]Jsoup(一)Jsoup详解(官方)
原文地址:http://www.cnblogs.com/zhangyinhua/p/8037599.html 一.Jsoup概述 1.1.简介 jsoup 是一款Java 的HTML解析器,可 ...