广告
返回顶部
首页 > 资讯 > 后端开发 > Python >mybatis如何批量修改数据
  • 744
分享到

mybatis如何批量修改数据

2024-04-02 19:04:59 744人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录批量修改主要有两种方式第一种第二种Mysql及mybatis批量更新数据updatemysql批量更新updatemybatis实现批量更新update批量修改主要有两种方式 第

批量修改主要有两种方式

第一种

可以通过for循环一条一条修改数据,这样会影响效率,因此我不推荐,所以在这里我也不多说。

第二种

通过修改mybatis中mapper.xml文件,如下:

<update id="updateRoleMenus" parameterType="java.util.List"> 
      <foreach collection="list" item="item" index="index" open="" close="" separator=";"> 
       update TB_ROLE_MENU  
          <set> 
          FID=#{item.fid}
          </set> 
          where ROLEID = #{item.roleid} 
      </foreach> 
    </update>

mysql及mybatis批量更新数据update

mysql批量更新update

使用case when语句,数据表如下:

case1:

其中age为非空字段。sql如下

update test1
set age=case
when id=2 then 1
when id =3 then 2
end
where id in (2,3,4)

对id为2,3,4的设置age字段,id为2的设置为1,3的设置为2,结果为:

Column ‘age’ cannot be null.

原因是由于id=4没有被上面的when匹配到,因此会被默认设为空null。即未被匹配到的记录并不会保持原来的数值,而是会被设置为null。

case2:

如果想设默认值,可写为:

update test1
set age=case
when id=2 then 1
when id =3 then 2
else 30
end
where id in (2,3,4)

结果是

可见id=4的设为了30,也就是通过else default_value可以对未被匹配到的行设置默认值。

case3:

如果想对未匹配到的行设置未原来的值,则可写为:

update test1
set age=case
when id=2 then 1
when id =3 then 2
when id =4 then test1.age
end
where id in (2,3,4)

这样就可以通过test1.age来使id=4的行保持原值。在mybatis中可看到这种写法的用处。

mybatis实现批量更新update

对应上面的各种case,来写xml。

通常在写代码的时候,有时候不更新的字段就不会设置到对象里,比如Person对象分别有id,name,age三个属性对应数据库的三个字段,如果不想更新id=4的age时,就通常不设置age的值,也就是age=null,这样在case1里,就会被误设为null,详细见如下代码。

case1:

update test1
<set>
	<trim prefix="age=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			<if test="item.age !=null">
				when id=#{item.id} then #{item.age}
			</if>
		</foreach>
	</trim>
	<trim prefix="name=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			when id=#{item.id} then #{item.name}
		</foreach>
	</trim>
</set>
where id in
<foreach collection="list" item="item" index="index" separator="," open="(" close=")">
	#{item.id}
</foreach>

当传入的list中person对象有三个,分别对应id=2,3,4,若不想更新4的age,而只想更新4的姓名,则id=4的person对象age就会被设为null,这样传入该sql时,id=4的数据不会被when匹配,而又没有设置默认值,则原数据会被删除并设为null。

case2:

update test1
<set>
	<trim prefix="age=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			<if test="item.age !=null">
				when id=#{item.id} then #{item.age}
			</if>
		</foreach>
		else 30
	</trim>
	<trim prefix="name=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			when id=#{item.id} then #{item.name}
		</foreach>
	</trim>
</set>
where id in
<foreach collection="list" item="item" index="index" separator="," open="(" close=")">
	#{item.id}
</foreach>

该代码由于设置了else 30,因此会id=4的数据在不设置age的情况下会被更新为30。

case3:

update test1
<set>
	<trim prefix="age=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			<if test="item.age !=null">
				when id=#{item.id} then #{item.age}
			</if>
			<if test="item.age ==null">
				when id=#{item.id} then test1.age
			</if>
		</foreach>
	</trim>
	<trim prefix="name=case" suffix="end,">
		<foreach collection="list" item="item" index="index">
			when id=#{item.id} then #{item.name}
		</foreach>
	</trim>
</set>
where id in
<foreach collection="list" item="item" index="index" separator="," open="(" close=")">
	#{item.id}
</foreach>

通过if标签,若传入的属性为null,则保持数据库原值。

补充:

更新多条数据同一字段为同一值:

UPDATE test1 SET age=24 WHERE id in(2,3,4);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: mybatis如何批量修改数据

本文链接: https://www.lsjlt.com/news/142388.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis如何批量修改数据
    目录批量修改主要有两种方式第一种第二种mysql及mybatis批量更新数据updatemysql批量更新updatemybatis实现批量更新update批量修改主要有两种方式 第...
    99+
    2022-11-13
  • mybatis怎么批量修改数据
    这篇文章给大家分享的是有关mybatis怎么批量修改数据的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。批量修改主要有两种方式第一种可以通过for循环一条一条修改数据,这样会影响效率,因此我不推荐,所以在这里我也不...
    99+
    2023-06-29
  • MyBatis批量插入/修改/删除MySql数据
    前言 由于项目需要生成多条数据,并保存到数据库当中,在程序中封装了一个List集合对象,然后需要把该集合中的实体插入到数据库中,项目使用了Spring+MyBatis,所以打算使用M...
    99+
    2022-11-12
  • Mybatis批量插入、修改
            在 MyBatis 中, 标签用于遍历集合类型的条件,并且可以将多个参数值拼接成为 SQL 语句的一个部分,通常被用于批量插入或更新等操作。  属性及介绍          属性介绍collection集合名称item字符别...
    99+
    2023-09-09
    java spring boot mybatis mysql
  • 利用Mybatis怎么对数据库进行批量修改
    这篇文章将为大家详细讲解有关利用Mybatis怎么对数据库进行批量修改,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。修改的字段值都是一样的,id不同<update id="b...
    99+
    2023-05-31
    mybatis
  • MyBatis怎么根据条件批量修改字段
    本篇内容介绍了“MyBatis怎么根据条件批量修改字段”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!MyBatis根据条件批量修改字段背景:...
    99+
    2023-07-05
  • mybatis实现批量修改-xml方式
    目录mybatis批量修改-xmlmybatis xml批量更新值mybatis批量修改-xml mybatis批量查询,批量新增就不聊了,今天看看批量修改。 直接上代码吧 xml文...
    99+
    2022-11-12
  • Java Mybatis批量修改封装详解
    重点重点重点,不然会报错 连接数据库url后面加个参数 allowMultiQueries=true 用习惯了 insertList 怎么能没有 updateList呢 就两个类...
    99+
    2022-11-12
  • Mybatis-Plus批量添加或修改数据的三种方式
    SpringBoot批量添加或修改数据的三种方式 方式一.Mybatis-plus 提供的 saveOrUpdateBatch 提供的方法 是遍历每一个元素,判断主键是否存在,如果存在则做更新,不存在...
    99+
    2023-10-12
    spring boot mybatis java mybatis-plus
  • Mybatis批量修改联合主键数据的两种方法
    最近遇上需要批量修改有联合主键的表数据,网上找了很多文章,最终都没找到比较合适的方法,有些只能支持少量数据批量修改,超过十几条就不行了。 最终自己摸索总结了两种方式可以批量修改数据。...
    99+
    2022-11-13
  • MyBatis根据条件批量修改字段的方式
    目录MyBatis根据条件批量修改字段代码以及注释MyBatis多条件批量修改简单记录下总结MyBatis根据条件批量修改字段 背景: 给学生改作业,只要是对的都批量进行数据库的修改...
    99+
    2023-02-22
    MyBatis批量修改字段 MyBatis修改字段 MyBatis条件修改字段
  • MyBatis如何批量插入大量数据
    这篇文章将为大家详细讲解有关MyBatis如何批量插入大量数据,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。问题背景:只用MyBatis中foreach进行批量插入数据,一次性插入超过一千条的时候MyBa...
    99+
    2023-06-22
  • navicat批量修改数据的方法
    这篇文章主要介绍了navicat批量修改数据的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。navicat是一个非常好用的数据库管理软件,今...
    99+
    2022-10-18
  • 数据库怎么批量修改一列数据
    要批量修改数据库中的一列数据,可以使用以下步骤: 首先,连接到数据库。这可以通过使用适当的数据库管理工具(如MySQL Work...
    99+
    2023-10-27
    数据库
  • MyBatis如何实现批量插入数据
    本文小编为大家详细介绍“MyBatis如何实现批量插入数据”,内容详细,步骤清晰,细节处理妥当,希望这篇“MyBatis如何实现批量插入数据”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、SQL实现示例假设我们...
    99+
    2023-07-04
  • Mybatis之批量更新数据
    Mybatis之批量更新数据(批量update) 前言 当我们使用mybatis的时候,可能经常会碰到一批数据的批量更新问题,因为如果一条数据一更新,那每一条数据就需要涉及到一次数据库的操作,包括网络...
    99+
    2023-09-12
    mybatis 数据库 mysql
  • eclipse如何批量修改变量名
    在Eclipse中,可以通过使用"重命名"功能来批量修改变量名。步骤如下:1. 打开Eclipse,并导入包含要修改变量名的项目。2...
    99+
    2023-10-18
    eclipse
  • 大批量数据分批批量插入或更新(Mybatis+MySQL)
    大批量数据分批批量插入或更新 在MySQL数据库的前提下,插入或更新大批量数据。首先批量插入需要考虑到以下几个因素: 数据库一次可以承受多大或者多少条数据的插入批量插入是否会占用Mysql资源太久,影响系统整体使用性能代码中的集合是否会造成...
    99+
    2023-08-30
    mybatis mysql 数据库 java spring boot
  • 如何进行mybatis实现批量修改xml方式的分析
    本篇文章为大家展示了如何进行mybatis实现批量修改xml方式的分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。mybatis批量修改-xmlmybatis批量查询,批量新增就不聊了,今天看看批...
    99+
    2023-06-21
  • mybatis批量新增、删除、查询和修改方式
    目录前期说明:主要有一下3种情况:(1)mybatis批量新增(2)mybatis批量删除(3)mybatis批量查询(4)mybatis批量修改mySql Case函数动态批量修改...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作