您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)mybatis怎么批量修改數(shù)據(jù)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
可以通過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>
使用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中可看到這種寫法的用處。
對(duì)應(yīng)上面的各種case,來寫xml。
通常在寫代碼的時(shí)候,有時(shí)候不更新的字段就不會(huì)設(shè)置到對(duì)象里,比如Person對(duì)象分別有id,name,age三個(gè)屬性對(duì)應(yīng)數(shù)據(jù)庫的三個(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ù)庫原值。
補(bǔ)充:
更新多條數(shù)據(jù)同一字段為同一值:
UPDATE test1 SET age=24 WHERE id in(2,3,4);
感謝各位的閱讀!關(guān)于“mybatis怎么批量修改數(shù)據(jù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。