mysql中insert?into...select語(yǔ)句優(yōu)化方式
insert into...select語(yǔ)句優(yōu)化
在MySQL中,INSERT INTO ... SELECT 語(yǔ)句可以導(dǎo)致源表(即SELECT部分的表)被鎖定,這主要取決于事務(wù)的隔離級(jí)別以及表的存儲(chǔ)引擎。
例如:
InnoDB存儲(chǔ)引擎在默認(rèn)的可重復(fù)讀(REPEATABLE READ)隔離級(jí)別下會(huì)使用一致性讀(consistent read)
通常不會(huì)鎖定源表中的記錄,但在某些情況下可能會(huì)使用間隙鎖(gap locks)或者next-key鎖,影響到并發(fā)性能。
優(yōu)化INSERT INTO ... SELECT語(yǔ)句的策略
使用低事務(wù)隔離級(jí)別:
- 例如,將隔離級(jí)別設(shè)置為READ COMMITTED可以減少鎖的使用
- 但在修改隔離級(jí)別前需要考慮應(yīng)用程序的整體一致性要求
分批插入:
- 若向目標(biāo)表插入大量數(shù)據(jù),可以考慮將其拆分成多個(gè)小批量的插入操作。
- 這樣可以減少對(duì)源表的鎖定時(shí)間,并降低對(duì)數(shù)據(jù)庫(kù)性能的影響。
優(yōu)化SELECT查詢:
- 確保SELECT部分的查詢被高效執(zhí)行
- 比如使用索引來(lái)減少查詢時(shí)間和鎖定時(shí)間
限制索引鎖:
- 如果使用InnoDB并且確實(shí)出現(xiàn)了間隙鎖定
- 可以通過(guò)優(yōu)化查詢條件來(lái)減少間隙鎖的使用
避免高峰時(shí)段操作:
- 盡量避免在系統(tǒng)負(fù)載高的時(shí)段運(yùn)行大型的INSERT INTO ... SELECT操作。
使用INSERT DELAYED:
- 如果表的存儲(chǔ)引擎支持(如MyISAM)
- 可以使用INSERT DELAYED語(yǔ)句,它將插入操作排隊(duì),減少對(duì)表的即時(shí)鎖定。
調(diào)整鎖等待超時(shí)時(shí)間:
- 如果鎖沖突是一個(gè)問(wèn)題,可以調(diào)整鎖等待的超時(shí)時(shí)間
- 使得鎖定操作在等待太久后能夠失敗并重新嘗試
使用臨時(shí)表:
- 先將數(shù)據(jù)插入到臨時(shí)表中,然后再?gòu)呐R時(shí)表批量轉(zhuǎn)移到目標(biāo)表
- 這種方法可以減少對(duì)原始表的鎖定時(shí)間
考慮使用pt-online-schema-change或gh-ost工具:
- 如果要對(duì)大表進(jìn)行DDL操作并且想要最小化鎖的影響
- 可以使用這些工具進(jìn)行在線DDL更改
需要注意的是,具體的優(yōu)化策略取決于具體的使用場(chǎng)景,性能瓶頸的原因以及數(shù)據(jù)的特點(diǎn)。
因此,實(shí)施任何優(yōu)化之前都應(yīng)該仔細(xì)分析和測(cè)試以確保不會(huì)對(duì)系統(tǒng)的穩(wěn)定性和數(shù)據(jù)的一致性產(chǎn)生負(fù)面影響。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- SQL?Server使用SELECT?INTO實(shí)現(xiàn)表備份的代碼示例
- sql中select into和insert select的用法小結(jié)
- MySQL insert into select 主鍵沖突解決方案
- mysql使用insert into select插入查出的數(shù)據(jù)
- SELECT...INTO的具體用法
- 使用MySQL實(shí)現(xiàn)select?into臨時(shí)表的功能
- 用SELECT... INTO OUTFILE語(yǔ)句導(dǎo)出MySQL數(shù)據(jù)的教程
- SELECT INTO用法及支持的數(shù)據(jù)庫(kù)
相關(guān)文章
mysql查詢語(yǔ)句通過(guò)limit來(lái)限制查詢的行數(shù)
這篇文章主要介紹了mysql查詢語(yǔ)句,通過(guò)limit來(lái)限制查詢的行數(shù),需要的朋友可以參考下2014-02-02
阿里云centos7安裝mysql8.0.22的詳細(xì)教程
這篇文章主要介紹了阿里云centos7安裝mysql8.0.22的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
淺談mysql通配符進(jìn)行模糊查詢的實(shí)現(xiàn)方法
這篇文章主要介紹了淺談mysql通配符進(jìn)行模糊查詢,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
MYSQL??group?by?有哪些注意事項(xiàng)
這篇文章主要介紹了MYSQL??group?by?有哪些注意事項(xiàng),比如我們不能在?group?by?之后添加?where?查詢語(yǔ)句,更多相關(guān)分享,需要的朋友可以參考下面文章內(nèi)容2022-07-07
MySQL?alter命令修改表語(yǔ)法實(shí)例詳解
這篇文章主要給大家介紹了關(guān)于MySQL?alter命令修改表語(yǔ)法實(shí)例詳解的相關(guān)資料,在MySQL中ALTER指令的作用是修改已存在的數(shù)據(jù)庫(kù)表的結(jié)構(gòu),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
怎樣設(shè)置才能允許外網(wǎng)訪問(wèn)MySQL
大多數(shù)情況下,mysql數(shù)據(jù)庫(kù)只要本機(jī)訪問(wèn)就可以了,這樣的話,默認(rèn)安裝就OK,但是如果需要外網(wǎng)訪問(wèn)mysql數(shù)據(jù)庫(kù)的話,應(yīng)該如何操作呢,想知道的話,就好好看看下面的介紹吧2014-08-08
Lost connection to MySQL server during query的解決
經(jīng)常在執(zhí)行sql語(yǔ)句時(shí),會(huì)發(fā)現(xiàn)這個(gè)問(wèn)題,一般就是連接mysql數(shù)據(jù)庫(kù)不穩(wěn)定2008-06-06

