欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis如何批量修改數(shù)據(jù)

 更新時(shí)間:2022年03月14日 11:47:39   作者:白雪茫茫  
這篇文章主要介紹了mybatis如何批量修改數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

批量修改主要有兩種方式

第一種

可以通過for循環(huán)一條一條修改數(shù)據(jù),這樣會(huì)影響效率,因此我不推薦,所以在這里我也不多說。

第二種

通過修改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批量更新數(shù)據(jù)update

mysql批量更新update

使用case when語句,數(shù)據(jù)表如下:

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)

對(duì)id為2,3,4的設(shè)置age字段,id為2的設(shè)置為1,3的設(shè)置為2,結(jié)果為:

Column ‘age’ cannot be null.

原因是由于id=4沒有被上面的when匹配到,因此會(huì)被默認(rèn)設(shè)為空null。即未被匹配到的記錄并不會(huì)保持原來的數(shù)值,而是會(huì)被設(shè)置為null。

case2:

如果想設(shè)默認(rèn)值,可寫為:

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

結(jié)果是

可見id=4的設(shè)為了30,也就是通過else default_value可以對(duì)未被匹配到的行設(shè)置默認(rèn)值。

case3:

如果想對(duì)未匹配到的行設(shè)置未原來的值,則可寫為:

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實(shí)現(xiàn)批量更新update

對(duì)應(yīng)上面的各種case,來寫xml。

通常在寫代碼的時(shí)候,有時(shí)候不更新的字段就不會(huì)設(shè)置到對(duì)象里,比如Person對(duì)象分別有id,name,age三個(gè)屬性對(duì)應(yīng)數(shù)據(jù)庫(kù)的三個(gè)字段,如果不想更新id=4的age時(shí),就通常不設(shè)置age的值,也就是age=null,這樣在case1里,就會(huì)被誤設(shè)為null,詳細(xì)見如下代碼。

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>

當(dāng)傳入的list中person對(duì)象有三個(gè),分別對(duì)應(yīng)id=2,3,4,若不想更新4的age,而只想更新4的姓名,則id=4的person對(duì)象age就會(huì)被設(shè)為null,這樣傳入該sql時(shí),id=4的數(shù)據(jù)不會(huì)被when匹配,而又沒有設(shè)置默認(rèn)值,則原數(shù)據(jù)會(huì)被刪除并設(shè)為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>

該代碼由于設(shè)置了else 30,因此會(huì)id=4的數(shù)據(jù)在不設(shè)置age的情況下會(huì)被更新為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標(biāo)簽,若傳入的屬性為null,則保持?jǐn)?shù)據(jù)庫(kù)原值。

補(bǔ)充:

更新多條數(shù)據(jù)同一字段為同一值:

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

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java8 stream 操作map根據(jù)key或者value排序的實(shí)現(xiàn)

    java8 stream 操作map根據(jù)key或者value排序的實(shí)現(xiàn)

    這篇文章主要介紹了java8 stream 操作map根據(jù)key或者value排序的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • MyBatis字段名和屬性名不一致的解決方法

    MyBatis字段名和屬性名不一致的解決方法

    本文主要介紹了MyBatis字段名和屬性名不一致的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • SpringBoot單機(jī)限流的實(shí)現(xiàn)

    SpringBoot單機(jī)限流的實(shí)現(xiàn)

    在系統(tǒng)運(yùn)維中, 有時(shí)候?yàn)榱吮苊庥脩舻膼阂馑⒔涌? 會(huì)加入一定規(guī)則的限流,本文主要介紹了SpringBoot單機(jī)限流的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • 簡(jiǎn)單介紹java中equals以及==的用法

    簡(jiǎn)單介紹java中equals以及==的用法

    這篇文章主要介紹了簡(jiǎn)單介紹java中equals以及==的用法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Servlet實(shí)現(xiàn)分頁效果

    Servlet實(shí)現(xiàn)分頁效果

    這篇文章主要為大家詳細(xì)介紹了Servlet實(shí)現(xiàn)分頁效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Java文件寫入器FileWriter使用指南

    Java文件寫入器FileWriter使用指南

    在Java中,FileWriter類用于將字符寫入文件中,它繼承了Writer類,因此可以使用Writer類中的所有方法,下面我們就來深入探討一下FileWriter類的使用方法吧
    2023-10-10
  • springboot做代理分發(fā)服務(wù)+代理鑒權(quán)的實(shí)現(xiàn)過程

    springboot做代理分發(fā)服務(wù)+代理鑒權(quán)的實(shí)現(xiàn)過程

    這篇文章主要介紹了springboot做代理分發(fā)服務(wù)+代理鑒權(quán)的實(shí)現(xiàn)過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Java執(zhí)行hadoop的基本操作實(shí)例代碼

    Java執(zhí)行hadoop的基本操作實(shí)例代碼

    這篇文章主要介紹了Java執(zhí)行hadoop的基本操作實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • java?System類和Arrays類詳解

    java?System類和Arrays類詳解

    這篇文章主要介紹了java?System類和Arrays類詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • SpringBoot容器的主要組件詳解

    SpringBoot容器的主要組件詳解

    這篇文章主要介紹了SpringBoot容器的主要組件詳解,SpringBoot?是基于?Spring?Framework?的一種快速開發(fā)框架,它可以幫助開發(fā)者快速地構(gòu)建獨(dú)立的、生產(chǎn)級(jí)別的、可部署的應(yīng)用程序,需要的朋友可以參考下
    2023-09-09

最新評(píng)論