MySQL常見的sql優(yōu)化語句

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

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的仁布網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

大批量插入數(shù)據(jù)
1. 對(duì)于Myisam 類型的表,可以通過以下方式快速的導(dǎo)入大量的數(shù)據(jù)。
ALTER TABLE tblname DISABLE KEYS;
loading the data
ALTER TABLE tblname ENABLE KEYS;
 
這兩個(gè)命令用來打開或者關(guān)閉Myisam 表非唯一索引的更新。在導(dǎo)入大量的數(shù)據(jù)到一個(gè)非空的Myisam 表時(shí),通過設(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 表沒有主鍵,那么系統(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,打開自動(dòng)提交,也可以提高導(dǎo)入的效率。
 
優(yōu)化insert語句
如果你同時(shí)從同一客戶插入很多行,使用多個(gè)值表的INSERT 語句。這比使用分開 INSERT 語句快(在一些情況中幾倍)。Insert into test values(1,2),(1,3),(1,4)…
 
如果你從不同客戶插入很多行,能通過使用INSERT DELAYED 語句得到更高的速度。Delayed 的含義是讓insert 語句馬上執(zhí)行,其實(shí)數(shù)據(jù)都被放在內(nèi)存的隊(duì)列中,并沒有真正的寫入磁盤;這比每條語句都分別插入要快的多;LOW_PRIORITY剛好相反,在所有其他用戶對(duì)表的讀寫完成后才進(jìn)行插入。
 
將索引文件和數(shù)據(jù)文件分在不同的磁盤上存放(利用建表中的選項(xiàng));
如果進(jìn)行批量插入,可以增加bulk_insert_buffer_size 變量值的方法來提高速度,但是,這只能對(duì)myisam表使用;  www.2cto.com  
 
當(dāng)從一個(gè)文本文件裝載一個(gè)表時(shí),使用LOAD DATA INFILE。這通常比使用很多INSERT語句快20倍;
根據(jù)應(yīng)用情況使用replace 語句代替insert;
根據(jù)應(yīng)用情況使用ignore 關(guān)鍵字忽略重復(fù)記錄。
 
優(yōu)化Group By語句
默認(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語句
在某些情況中,MySQL 可以使用一個(gè)索引來滿足ORDER BY 子句,而不需要額外的排序。where 條件和order by 使用相同的索引,并且order by 的順序和索引順序相同,并且order by 的字段都是升序或者都是降序。

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

文章標(biāo)題:MySQL常見的sql優(yōu)化語句
文章網(wǎng)址:http://bm7419.com/article22/goepcc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、企業(yè)網(wǎng)站制作、Google、靜態(tài)網(wǎng)站、品牌網(wǎng)站制作、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)