Mybatis的update更新批量與普通解決方式對比
需求前提:
通過其他庫里面查詢出一條數(shù)據(jù),并且對另外一個庫中的oederId進行更新里面的內(nèi)容
注意:使用批量update時連接數(shù)據(jù)庫的語句需要添加allowMultiQueries=true
jdbc:mysql://127.0.0.1:3306/tb?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8&useSSL=false&allowMultiQueries=true
1.第一種:應該是效率最低的更新
查詢出來直接進行update修改語句

2.通過批量更新
通過查詢匹配存在表里面的數(shù)據(jù),就把需要更新的數(shù)據(jù)添加到一個集合中去,在xml使用foreach來更新數(shù)據(jù),如果需要插入的數(shù)據(jù)太長可能存在一些問題,那我們我們把需要插入的集合進行分批插入,這樣也不至于update語句連起來太長了

通過subList方法來截取插入的數(shù)量,我們按照500條進行分批插入.

使用該方法必須使用左父右子的形式才能使用父類的方法.
List< T > uptbDtos=new ArrayList<>();
xml改造
<update id="updateOrderXqlDatas">
<foreach collection="list" index="index" item="item" separator=";" open="" close="">
UPDATE tb_taobao_order
<set>
<if test="item.wxid != null"> wxid = #{item.wxid},</if>
<if test="item.wxname != null"> wxname = #{item.wxname}</if>
</set>
WHERE
TRADE_ID = #{item.tradeid,jdbcType=VARCHAR}
</foreach>
</update>
輸出的sql語句:
update tb_taobao_order set wxid='1' ,wxname='哈哈哈' where TRADE_ID='5456';update tb_taobao_order set wxid='2' ,wxname='哈哈哈2' where TRADE_ID='5458';
會以這種形式拼接起來然后在一起運行!和第一種的區(qū)別在于,第一種是單條update的運行提交!
注意事項:使用set導致逗號出現(xiàn)的問題
如果修改多個值的時候使用需要使用逗號分隔,都是會有一種情況如果對象的值是null那么使用if標簽的值就不會會被插入,這樣就會出現(xiàn)一個問題,如果對象里面的wxname是null那么插入的語句會變成:update tb_taobao_order set wxid='1' , where TRADE_ID='5456';你會發(fā)現(xiàn)wxid=‘1’ 后面跟著一個逗號這樣的sql肯定會報錯的!**
解決這一個問題:我們把set標簽更改掉換成trim標簽
<foreach collection="list" index="index" item="item" separator=";" open="" close="">
UPDATE tb_taobao_order
<trim prefix="set" suffixOverrides=",">
<if test="item.wxid != null"> wxid = #{item.wxid},</if>
<if test="item.wxname != null"> wxname = #{item.wxname}</if>
</trim>
WHERE
TRADE_ID = #{item.tradeid,jdbcType=VARCHAR}
</foreach>
< trim>節(jié)點標簽解讀:
屬性:
prefix:trim包含的內(nèi)容前加上某些前綴
suffix:trim包含的內(nèi)容后面添加后綴
prefixOverrides:內(nèi)容首部的某些內(nèi)容去掉
suffixOverrides:內(nèi)容的尾部的某些內(nèi)容去掉
好了修改好后,運行程序開始同步數(shù)據(jù)

同步時間從原來的1020秒變成現(xiàn)在的16秒速度提升多少呀

沒有進行批量更新的時間!
以上就是Mybatis的update更新批量與普通解決方式對比的詳細內(nèi)容,更多關于Mybatis update更新批量普通對比的資料請關注腳本之家其它相關文章!
相關文章
SpringBoot讀取resource目錄下文件失敗的原因及解決方案
在idea中運行時,有些resource下文件讀取工具類能夠正常獲取讀取到文件,但是通過java–jar的方式去運行jar包,此時resource下文件讀取工具類讀取文件就失效了,本文就給大家介紹一下SpringBoot讀取resource目錄下文件失敗解決方案,需要的朋友可以參考下2023-08-08

