千萬級的mysql數(shù)據(jù)庫與優(yōu)化方法_第1頁
千萬級的mysql數(shù)據(jù)庫與優(yōu)化方法_第2頁
千萬級的mysql數(shù)據(jù)庫與優(yōu)化方法_第3頁
千萬級的mysql數(shù)據(jù)庫與優(yōu)化方法_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、千萬級的mysql數(shù)據(jù)庫與優(yōu)化方法1 .對查詢進(jìn)行優(yōu)化,應(yīng)盡量避免全表掃描,首先應(yīng)考慮在where及orderby涉及的列上建立索引。2 .應(yīng)盡量避免在where子句中對字段進(jìn)行null值判斷,否則將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描,如:Sql代碼1.selectidfromtwherenumisnull可以在num上設(shè)置默認(rèn)值0,確保表中num列沒有null值,然后這樣查詢:Sql代碼1.selectidfromtwherenum=03 .應(yīng)盡量避免在where子句中使用!=或操作符,否則將引擎放棄使用索引而進(jìn)行全表掃描。4 .應(yīng)盡量避免在where子句中使用or來連接條件,否則將導(dǎo)致引擎

2、放棄使用索引而進(jìn)行全表掃描,如:Sql代碼1. selectidfromtwherenum=10ornum=20可以這樣查詢:Sql代碼1.selectidfromtwherenum=102.unionall3.selectidfromtwherenum=201.1 n和notin也要慎用,否則會導(dǎo)致全表掃描,如:Sql代碼1. selectidfromtwherenumin(1,2,3)對于連續(xù)的數(shù)值,能用between就不要用in了:Sql代碼2. selectidfromtwherenumbetween1and31. .下面的查詢也將導(dǎo)致全表掃描:Sql代碼selectidfromtwh

3、erenamelikec%若要提高效率,可以考慮全文檢索。2. .如果在where子句中使用參數(shù),也會導(dǎo)致全表掃描。因?yàn)镾QL只有在運(yùn)行時才會解析局部變量,但優(yōu)化程序不能將訪問計(jì)劃的選擇推遲到運(yùn)行時;它必須在編譯時進(jìn)行選擇。然而,如果在編譯時建立訪問計(jì)劃,變量的值還是未知的,因而無法作為索引選擇的輸入項(xiàng)。如下面語句將進(jìn)行全表掃描:Sql代碼selectidfromtwherenum=num可以改為強(qiáng)制查詢使用索引:Sql代碼selectidfromtwith(index(索弓I名)wherenum=num.應(yīng)盡量避免在where子句中對字段進(jìn)行表達(dá)式操作,這將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描

4、。如:Sql代碼000000000000 selectidfromtwherenum/2=100應(yīng)改為:Sql代碼111111111111 selectidfromtwherenum=100*2.應(yīng)盡量避免在where子句中對字段進(jìn)行函數(shù)操作,這將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描。如:Sql代碼selectidfromtwheresubstring(name,1,3)=abcname以abc開頭的idselectidfromtwheredatediff(day,createdate,200511-30)=0-200151-30生成的id應(yīng)改為:Sql代碼selectidfromtwheren

5、amelikeabc%selectidfromtwherecreatedate=200511-30andcreatedate,=,=)和orderby、groupby發(fā)生的列,可考慮建立群集索引;b.經(jīng)常同時存取多列,且每列都含有重復(fù)值可考慮建立組合索引;c.組合索引要盡量使關(guān)鍵查詢形成索引覆蓋,其前導(dǎo)列一定是使用最頻繁的列。索引雖有助于提高性能但不是索引越多越好,恰好相反過多的索引會導(dǎo)致系統(tǒng)低效。用戶在表中每加進(jìn)一個索引,維護(hù)索引集合就要做相應(yīng)的更新工作。2、在海量查詢時盡量少用格式轉(zhuǎn)換。ORDERBY和GROPUBY:使用ORDERBY和GROUPBY短語,任何一種索引者B有助于SELECT的性能提高。4、任何對列的操作都將導(dǎo)致表掃描,它包括數(shù)據(jù)庫教程函數(shù)、計(jì)算表達(dá)式等等,查詢時要盡可能將操作移至等號右邊。5、IN、OR子句常會使用工作表,使索引失效。如果不產(chǎn)生大量重復(fù)值,可以考慮把子句拆開。拆開的子句中應(yīng)該包含索引。6、只要能滿足你的需求,應(yīng)盡可能使用更小的數(shù)據(jù)類型:例如使用MEDIUMINT代替INT7、盡量把所有的列設(shè)置為NOTNULL,如果你要保存NULL,手動去設(shè)置它,

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論