MySQL批量更新的四種方式總結(jié)
直接update的弊端
最近做一個(gè)需求,更新3w條數(shù)據(jù),一個(gè)一個(gè)update去更新的,結(jié)果花了80分鐘,這樣性能上很差,也容易阻塞,所以就找了一些MySQL批量更新的方式,在此記錄一下
方法一;replace into
這種更新會(huì)將其它字段更新為默認(rèn)值,因?yàn)樗窍葘⒅貜?fù)記錄刪掉再更新,謹(jǐn)慎使用
replace into `user` (id,age) values (1,'2'),(2,'3'),(3,'4'),(4,'98'); -- > 時(shí)間: 0.038s
方法二:insert into [table] values… on duplicate key update
這種方式應(yīng)該也是刪掉記錄,再更新,但是保存的原來(lái)的其它字段數(shù)據(jù),所以其它字段不會(huì)改變
insert into `user`(id,age) values (1,'5'),(2,'7'),(3,'2'),(4,'198') on duplicate key update age=values(age) -- > > 時(shí)間: 0.017s
方法三:創(chuàng)建臨時(shí)表
創(chuàng)建臨時(shí)表,將更新數(shù)據(jù)插入臨時(shí)表,再執(zhí)行更新,需要有建表權(quán)限
DROP TABLE if EXISTS tmp; -- > 時(shí)間: 0.016s create temporary table tmp(id int(4) primary key,age varchar(50)); -- > 時(shí)間: 0.01s insert into tmp values (1,'13'), (2,'16'),(3,'18'),(4,'18'); -- > 時(shí)間: 0.009s update `user`, tmp set `user`.age=tmp.age where `user`.id=tmp.id; -- > 時(shí)間: 0.022s
方法四:使用MySQL自帶批量更新語(yǔ)句
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); -- > 時(shí)間: 0.015s update (表名) set (更新字段) = case (被更新字段) when (被更新字段值) then (更新字段值)... end where (被更新字段) in((被更新字段值)...)
舉例說(shuō)明:set age = CASE id WHEN 1 THEN ‘22’
簡(jiǎn)單來(lái)說(shuō)就是以id為查詢條件,當(dāng)id=1時(shí)更新age=22,where語(yǔ)句提高了sql的執(zhí)行效率,先過(guò)濾需要修改的記錄然后再更新。
總結(jié)
到此這篇關(guān)于MySQL批量更新的四種方式的文章就介紹到這了,更多相關(guān)MySQL批量更新內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql臨時(shí)表原理及創(chuàng)建方法解析
這篇文章主要介紹了Mysql臨時(shí)表原理及創(chuàng)建方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12mysql in語(yǔ)句子查詢效率慢的優(yōu)化技巧示例
本文介紹主要介紹在mysql中使用in語(yǔ)句時(shí),查詢效率非常慢,這里分享下我的解決方法,供朋友們參考。2017-10-10Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)重裝mysql
這篇文章主要介紹了Windows系統(tǒng)中完全卸載MySQL數(shù)據(jù)庫(kù)實(shí)現(xiàn)重裝mysql數(shù)據(jù)庫(kù)的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-05-05在MySQL中使用mysqlbinlog flashback的簡(jiǎn)單教程
這篇文章主要介紹了在MySQL中使用mysqlbinlog flashback的簡(jiǎn)單教程,可以很方便地恢復(fù)數(shù)據(jù),作者還列出了使用時(shí)一些需要注意的地方,需要的朋友可以參考下2015-05-05mysql如何通過(guò)my.ini更改默認(rèn)字符集
這篇文章主要介紹了mysql如何通過(guò)my.ini更改默認(rèn)字符集問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Mysql中where與on的區(qū)別及何時(shí)使用詳析
MySQL當(dāng)中的限制條件可以使用on或者where,兩者在不同的情況下具有不同而意義,這篇文章主要給大家介紹了關(guān)于Mysql中where與on的區(qū)別及何時(shí)使用的相關(guān)資料,需要的朋友可以參考下2021-08-08MySQL模糊查找like通配符使用(小白入門(mén)篇)
這篇文章主要為大家介紹了MySQL模糊查找like通配符使用的小白入門(mén)篇學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05