



下載本文檔
版權(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 石油化工工程師的未來發(fā)展趨勢
- 構(gòu)建職安教育培訓(xùn)的多元化體系
- 醫(yī)療合同范本模板
- 智能照明在緊急救援照明中的應(yīng)用考核試卷
- 收梨合同范本
- 高層建筑保安工作的獨(dú)特要求計(jì)劃
- 科技引領(lǐng)下的商業(yè)智能化改造建議
- 室內(nèi)游藝器材產(chǎn)品功能測試與優(yōu)化考核試卷
- 財(cái)務(wù)合規(guī)性審查計(jì)劃
- 班主任工作計(jì)劃開啟學(xué)生美好未來
- 個人合伙開店合同范本
- 生而為贏自燃成陽-開學(xué)第一課發(fā)言稿
- 2025年中國國投高新產(chǎn)業(yè)投資集團(tuán)招聘筆試參考題庫含答案解析
- 年產(chǎn)10噸功能益生菌凍干粉的工廠設(shè)計(jì)改
- 醫(yī)院護(hù)士勞動合同
- 醫(yī)師聘用證明.doc
- 核物理實(shí)驗(yàn)方法全冊配套最完整精品課件
- 理論力學(xué)課件00796
- 學(xué)習(xí)疊層母排必須知道的電力知識
- 微波與天線矩形波導(dǎo)
- 19+張愛玲經(jīng)典《金鎖記》英文版
評論
0/150
提交評論