欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

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

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

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

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

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

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

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

廣告

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

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