溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL常見(jiàn)的sql優(yōu)化語(yǔ)句

發(fā)布時(shí)間:2021-09-15 14:58:45 來(lái)源:億速云 閱讀:144 作者:chen 欄目:數(shù)據(jù)庫(kù)

本篇內(nèi)容介紹了“MySQL常見(jiàn)的sql優(yōu)化語(yǔ)句”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

大批量插入數(shù)據(jù)
1. 對(duì)于Myisam 類型的表,可以通過(guò)以下方式快速的導(dǎo)入大量的數(shù)據(jù)。
ALTER TABLE tblname DISABLE KEYS;
loading the data
ALTER TABLE tblname ENABLE KEYS;
 
這兩個(gè)命令用來(lái)打開(kāi)或者關(guān)閉Myisam 表非唯一索引的更新。在導(dǎo)入大量的數(shù)據(jù)到一個(gè)非空的Myisam 表時(shí),通過(guò)設(shè)置這兩個(gè)命令,可以提高導(dǎo)入的效率。對(duì)于導(dǎo)入大量數(shù)據(jù)到一個(gè)空的Myisam 表,默認(rèn)就是先導(dǎo)入數(shù)據(jù)然后才創(chuàng)建索引的,所以不用進(jìn)行設(shè)置。
 
2. 而對(duì)于Innodb 類型的表,這種方式并不能提高導(dǎo)入數(shù)據(jù)的效率。對(duì)于Innodb 類型的表,我們有以下幾種方式可以提高導(dǎo)入的效率:  www.2cto.com  
a. 因?yàn)镮nnodb 類型的表是按照主鍵的順序保存的,所以將導(dǎo)入的數(shù)據(jù)按照主鍵的順序排列,可以有效的提高導(dǎo)入數(shù)據(jù)的效率。如果Innodb 表沒(méi)有主鍵,那么系統(tǒng)會(huì)默認(rèn)創(chuàng)建一個(gè)內(nèi)部列作為主鍵,所以如果可以給表創(chuàng)建一個(gè)主鍵,將可以利用這個(gè)優(yōu)勢(shì)提高導(dǎo)入數(shù)據(jù)的效率。
 
b. 在導(dǎo)入數(shù)據(jù)前執(zhí)行SET UNIQUE_CHECKS=0,關(guān)閉唯一性校驗(yàn),在導(dǎo)入結(jié)束后執(zhí)行SETUNIQUE_CHECKS=1,恢復(fù)唯一性校驗(yàn),可以提高導(dǎo)入的效率。
c. 如果應(yīng)用使用自動(dòng)提交的方式,建議在導(dǎo)入前執(zhí)行SET AUTOCOMMIT=0,關(guān)閉自動(dòng)提交,導(dǎo)入結(jié)束后再執(zhí)行SET AUTOCOMMIT=1,打開(kāi)自動(dòng)提交,也可以提高導(dǎo)入的效率。
 
優(yōu)化insert語(yǔ)句
如果你同時(shí)從同一客戶插入很多行,使用多個(gè)值表的INSERT 語(yǔ)句。這比使用分開(kāi) INSERT 語(yǔ)句快(在一些情況中幾倍)。Insert into test values(1,2),(1,3),(1,4)…
 
如果你從不同客戶插入很多行,能通過(guò)使用INSERT DELAYED 語(yǔ)句得到更高的速度。Delayed 的含義是讓insert 語(yǔ)句馬上執(zhí)行,其實(shí)數(shù)據(jù)都被放在內(nèi)存的隊(duì)列中,并沒(méi)有真正的寫(xiě)入磁盤(pán);這比每條語(yǔ)句都分別插入要快的多;LOW_PRIORITY剛好相反,在所有其他用戶對(duì)表的讀寫(xiě)完成后才進(jìn)行插入。
 
將索引文件和數(shù)據(jù)文件分在不同的磁盤(pán)上存放(利用建表中的選項(xiàng));
如果進(jìn)行批量插入,可以增加bulk_insert_buffer_size 變量值的方法來(lái)提高速度,但是,這只能對(duì)myisam表使用;  www.2cto.com  
 
當(dāng)從一個(gè)文本文件裝載一個(gè)表時(shí),使用LOAD DATA INFILE。這通常比使用很多INSERT語(yǔ)句快20倍;
根據(jù)應(yīng)用情況使用replace 語(yǔ)句代替insert;
根據(jù)應(yīng)用情況使用ignore 關(guān)鍵字忽略重復(fù)記錄。
 
優(yōu)化Group By語(yǔ)句
默認(rèn)情況下,MySQL 排序所有GROUP BY col1,col2,....。查詢的方法如同在查詢中指定ORDER BY col1,col2,...。如果顯式包括一個(gè)包含相同的列的ORDER BY子句,MySQL 可以毫不減速地對(duì)它進(jìn)行優(yōu)化,盡管仍然進(jìn)行排序。如果查詢包括GROUP BY 但你想要避免排序結(jié)果的消耗,你可以指定ORDER BY NULL禁止排序。
 
優(yōu)化Order by語(yǔ)句
在某些情況中,MySQL 可以使用一個(gè)索引來(lái)滿足ORDER BY 子句,而不需要額外的排序。where 條件和order by 使用相同的索引,并且order by 的順序和索引順序相同,并且order by 的字段都是升序或者都是降序。

“MySQL常見(jiàn)的sql優(yōu)化語(yǔ)句”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI