亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MYSQL批量UPDATE的兩種方式小結(jié)

 更新時間:2024年11月15日 11:18:45   作者:turnsole_taurus  
本文主要介紹了兩種MySQL批量UPDATE的方式,SQL的foreach循環(huán)和使用INSERT...ON?DUPLICATE?KEY?UPDATE,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

工作中遇到批量更新的場景其實是比較常見的。
但是該如何正確的進行批量UPDATE,很多時候往往有點頭大。
這里列2種可用的方式,供選擇(請選擇方式一,手動狗頭。)。

如果使用了MyBatis增強組件MyBatisPlus,可以參考官網(wǎng)給出的解決方式(updateBatchById),或者自己查一下。

批量UPDATE方式一:SQL內(nèi)foreach

舉個??

<update id="updateUserForBatch" parameterType="com.bees.srx.entity.UserEntity">
	<foreach collection="list" item="entity" separator=";">
		UPDATE sys_user
		SET password=#{entity.password},age=#{entity.age}
		<where>
			id = #{entity.id}
		</where>
	</foreach>
</update>

這樣寫,肯定比 在業(yè)務(wù)方法中for循環(huán)單條update的效率是要高的。
但是如果遇到大批量的更新動作,可能也會產(chǎn)生效率低下的問題。
原因是SQL內(nèi)的foreach本質(zhì)上還是循環(huán)插入每一條數(shù)據(jù),會產(chǎn)生 list.size() 個單條插入的獨立SQL語句,每一條 UPDATE 語句都會被單獨發(fā)送到數(shù)據(jù)庫服務(wù)器執(zhí)行。
這意味著如果列表中有100個元素,就會產(chǎn)生100次數(shù)據(jù)庫往返通信。
這種方式不僅效率低下,而且對于大型批處理操作來說,可能會導(dǎo)致性能瓶頸和資源浪費。

優(yōu)化:通過JDBC批處理通過 MyBatis 的 SqlSession 提供的批處理功能來手動執(zhí)行批量更新。

try (SqlSession session = sqlSessionFactory.openSession(ExecutorType.BATCH)) {
    UserMapper mapper = session.getMapper(UserMapper.class);
    for (UserEntity user : userList) {
        mapper.updateUser(user);
    }
    session.commit();
}

這里mapper.updateUser就是單條的UPDATE語句。

通過這種方式,MyBatis 會在內(nèi)存中積累所有的更新命令,然后在調(diào)用session.commit() 時一次性提交給數(shù)據(jù)庫,這比逐條執(zhí)行要高效得多。

注意:是否存在效率差異,未實踐過?。?!可能存在誤人子弟的嫌疑。

批量UPDATE方式二:INSERT + ON DUPLICATE KEY UPDATE

 <update id="updateForBatch" parameterType="com.bees.srx.entity.UserEntity">
    insert into sys_user
    (id,username,password) values
    <foreach collection="list" index="index" item="item" separator=",">
        (#{item.id},
        #{item.username},
        #{item.password})
    </foreach>
    ON DUPLICATE KEY UPDATE
     password=values(password)
</update>

不建議使用。要求較多,而且容易出現(xiàn)死鎖。

注意事項

  • 唯一鍵約束:確保 sys_user 表中的 id 字段有唯一鍵約束(通常是主鍵)。如果 id 不是唯一的,ON DUPLICATE KEY UPDATE 將不會觸發(fā)更新操作。
  • 性能:這種方式在大數(shù)據(jù)量的情況下比多次單獨的 INSERT 和 UPDATE 操作要高效得多。
  • 事務(wù)管理:確保這個操作在一個事務(wù)中執(zhí)行,以保證數(shù)據(jù)的一致性。如果中間發(fā)生錯誤,可以回滾整個操作。
  • 字段順序:確保 VALUES 函數(shù)中的字段順序與 ON DUPLICATE KEY UPDATE 子句中的字段順序一致。

總結(jié):

建議使用方式一,或者其優(yōu)化方式(JDBC批處理)。

到此這篇關(guān)于MYSQL批量UPDATE的兩種方式小結(jié)的文章就介紹到這了,更多相關(guān)MYSQL批量UPDATE內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Ubuntu中MySQL的參數(shù)文件my.cnf示例詳析

    Ubuntu中MySQL的參數(shù)文件my.cnf示例詳析

    這篇文章主要給大家介紹了關(guān)于Ubuntu中MySQL的參數(shù)文件my.cnf的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • Mysql常用函數(shù)之Rank排名函數(shù)詳解

    Mysql常用函數(shù)之Rank排名函數(shù)詳解

    這篇文章主要介紹了Mysql常用函數(shù)之Rank排名函數(shù)詳解,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Mysql提升大數(shù)據(jù)表拷貝效率的解決方案

    Mysql提升大數(shù)據(jù)表拷貝效率的解決方案

    這篇文章主要給大家介紹了關(guān)于Mysql提升大數(shù)據(jù)表拷貝效率的解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09
  • mysql慢查詢?nèi)罩痉治龉ぞ呤褂?pt-query-digest)

    mysql慢查詢?nèi)罩痉治龉ぞ呤褂?pt-query-digest)

    這篇文章主要介紹了mysql慢查詢?nèi)罩痉治龉ぞ呤褂?pt-query-digest),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • LInux下安裝MySQL5.6 X64版本步驟詳解

    LInux下安裝MySQL5.6 X64版本步驟詳解

    這篇文章主要介紹了LInux下安裝MySQL5.6 X64版本步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySql下關(guān)于時間范圍的between查詢方式

    MySql下關(guān)于時間范圍的between查詢方式

    這篇文章主要介紹了MySql下關(guān)于時間范圍的between查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • mysql通過binlog日志復(fù)制主從同步的實現(xiàn)

    mysql通過binlog日志復(fù)制主從同步的實現(xiàn)

    本文主要介紹了mysql通過binlog日志復(fù)制主從同步的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • Mysql中的DCL權(quán)限詳解

    Mysql中的DCL權(quán)限詳解

    這篇文章主要介紹了Mysql中的DCL詳解,DCL是數(shù)據(jù)控制語言,用來管理用戶、控制數(shù)據(jù)庫的訪問權(quán)限,就控制有哪些用戶可以訪問數(shù)據(jù)庫,可以訪問數(shù)據(jù)庫的哪些內(nèi)容,需要的朋友可以參考下
    2023-08-08
  • MySQL修改默認字符集編碼的方法

    MySQL修改默認字符集編碼的方法

    這篇文章主要介紹了MySQL修改默認字符集編碼的方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09
  • Mysql中count(*)、count(1)、count(主鍵id)與count(字段)的區(qū)別

    Mysql中count(*)、count(1)、count(主鍵id)與count(字段)的區(qū)別

    本文主要介紹了Mysql中count(*)、count(1)、count(主鍵id)與count(字段)的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07

最新評論