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

MySQL批量更新的四種方式總結(jié)

 更新時間:2023年01月12日 15:11:46   作者:凌隕心  
最近需要批量更新大量數(shù)據(jù),習慣了寫sql,所以還是用sql來實現(xiàn),下面這篇文章主要給大家總結(jié)介紹了關于MySQL批量更新的四種方式,需要的朋友可以參考下

直接update的弊端

最近做一個需求,更新3w條數(shù)據(jù),一個一個update去更新的,結(jié)果花了80分鐘,這樣性能上很差,也容易阻塞,所以就找了一些MySQL批量更新的方式,在此記錄一下

方法一;replace into

這種更新會將其它字段更新為默認值,因為它是先將重復記錄刪掉再更新,謹慎使用

replace into `user` (id,age) values (1,'2'),(2,'3'),(3,'4'),(4,'98');
-- > 時間: 0.038s

方法二:insert into [table] values… on duplicate key update

這種方式應該也是刪掉記錄,再更新,但是保存的原來的其它字段數(shù)據(jù),所以其它字段不會改變

insert into `user`(id,age) values (1,'5'),(2,'7'),(3,'2'),(4,'198') on duplicate key update age=values(age)
-- > > 時間: 0.017s

方法三:創(chuàng)建臨時表

創(chuàng)建臨時表,將更新數(shù)據(jù)插入臨時表,再執(zhí)行更新,需要有建表權(quán)限

DROP TABLE if EXISTS tmp;
-- > 時間: 0.016s

create temporary table tmp(id int(4) primary key,age varchar(50));
-- > 時間: 0.01s

insert into tmp values  (1,'13'), (2,'16'),(3,'18'),(4,'18');
-- > 時間: 0.009s

update `user`, tmp set `user`.age=tmp.age where `user`.id=tmp.id;
-- > 時間: 0.022s

方法四:使用MySQL自帶批量更新語句

update `user`
	set age = CASE id
	WHEN 1 THEN '22'
	WHEN 2 THEN '22'
	WHEN 3 THEN '22'
	WHEN 4 THEN '22'
END WHERE id IN(1,2,3,4);
-- > 時間: 0.015s

update (表名)
set (更新字段) = case (被更新字段)
when (被更新字段值) then (更新字段值)...
end where (被更新字段) in((被更新字段值)...)

舉例說明:set age = CASE id WHEN 1 THEN ‘22’

簡單來說就是以id為查詢條件,當id=1時更新age=22,where語句提高了sql的執(zhí)行效率,先過濾需要修改的記錄然后再更新。

總結(jié)

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

相關文章

  • MySQL外鍵約束(FOREIGN KEY)案例講解

    MySQL外鍵約束(FOREIGN KEY)案例講解

    這篇文章主要介紹了MySQL外鍵約束(FOREIGN KEY)案例講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Mysql臨時表原理及創(chuàng)建方法解析

    Mysql臨時表原理及創(chuàng)建方法解析

    這篇文章主要介紹了Mysql臨時表原理及創(chuàng)建方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12
  • mysql解壓包的安裝基礎教程

    mysql解壓包的安裝基礎教程

    這篇文章主要為大家詳細介紹了mysql解壓包的安裝基礎教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • mysql in語句子查詢效率慢的優(yōu)化技巧示例

    mysql in語句子查詢效率慢的優(yōu)化技巧示例

    本文介紹主要介紹在mysql中使用in語句時,查詢效率非常慢,這里分享下我的解決方法,供朋友們參考。
    2017-10-10
  • Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql

    Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql

    這篇文章主要介紹了Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫實現(xiàn)重裝mysql數(shù)據(jù)庫的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • mysql里CST時區(qū)的坑及解決

    mysql里CST時區(qū)的坑及解決

    這篇文章主要介紹了mysql里CST時區(qū)的坑及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 在MySQL中使用mysqlbinlog flashback的簡單教程

    在MySQL中使用mysqlbinlog flashback的簡單教程

    這篇文章主要介紹了在MySQL中使用mysqlbinlog flashback的簡單教程,可以很方便地恢復數(shù)據(jù),作者還列出了使用時一些需要注意的地方,需要的朋友可以參考下
    2015-05-05
  • mysql如何通過my.ini更改默認字符集

    mysql如何通過my.ini更改默認字符集

    這篇文章主要介紹了mysql如何通過my.ini更改默認字符集問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Mysql中where與on的區(qū)別及何時使用詳析

    Mysql中where與on的區(qū)別及何時使用詳析

    MySQL當中的限制條件可以使用on或者where,兩者在不同的情況下具有不同而意義,這篇文章主要給大家介紹了關于Mysql中where與on的區(qū)別及何時使用的相關資料,需要的朋友可以參考下
    2021-08-08
  • MySQL模糊查找like通配符使用(小白入門篇)

    MySQL模糊查找like通配符使用(小白入門篇)

    這篇文章主要為大家介紹了MySQL模糊查找like通配符使用的小白入門篇學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05

最新評論