




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
查詢處理步驟
查詢分析首先,對(duì)查詢語句進(jìn)行掃描、詞法分析和語法分析。查詢檢查根據(jù)數(shù)據(jù)字典對(duì)合法的查詢語句進(jìn)行語義檢查,即檢查語句中的數(shù)據(jù)庫(kù)對(duì)象是否存在和是否有效。RDBMS一般用查詢樹(querytree)或稱為語法分析樹,來表示擴(kuò)展的關(guān)系代數(shù)表達(dá)式。查詢優(yōu)化查詢優(yōu)化就是選擇一個(gè)高效執(zhí)行的查詢處理策略。按照優(yōu)化的層次,查詢優(yōu)化可分為代數(shù)優(yōu)化和物理優(yōu)化。查詢執(zhí)行依據(jù)優(yōu)化器得到的執(zhí)行策略生成查詢計(jì)劃,由代碼生成器生成執(zhí)行這個(gè)查詢計(jì)劃的代碼。查詢優(yōu)化概述查詢優(yōu)化的必要性查詢優(yōu)化極大地影響RDBMS的性能。查詢優(yōu)化的可能性關(guān)系數(shù)據(jù)語言的級(jí)別很高,使DBMS可以從關(guān)系表達(dá)式中分析查詢語義。一、由DBMS進(jìn)行查詢優(yōu)化的好處二、查詢優(yōu)化目標(biāo)三、實(shí)際系統(tǒng)的查詢優(yōu)化步驟四、代價(jià)模型由DBMS進(jìn)行查詢優(yōu)化的好處好處一:用戶不必選擇存取路徑,不必考慮如何可以最好地表達(dá)查詢以獲得較好的效率;
好處二:系統(tǒng)可以比用戶程序的優(yōu)化做得更好。(1)優(yōu)化器可以從數(shù)據(jù)字典中獲取許多統(tǒng)計(jì)信息,而用戶程序則難以獲得這些信息;(2)如果數(shù)據(jù)庫(kù)的物理統(tǒng)計(jì)信息改變了,系統(tǒng)可以自動(dòng)對(duì)查詢重新優(yōu)化,以選擇相適應(yīng)的執(zhí)行計(jì)劃。而在非關(guān)系系統(tǒng)中必須重寫程序,而重寫程序在實(shí)際應(yīng)用中往往是不太可能的。(3)優(yōu)化器可以考慮數(shù)百種不同的執(zhí)行計(jì)劃,而程序員一般只能考慮有限的幾種可能性;(4)優(yōu)化器中包括了很多復(fù)雜的優(yōu)化技術(shù),自動(dòng)優(yōu)化使所有人擁有這些技術(shù)。查詢優(yōu)化目標(biāo)查詢優(yōu)化的總目標(biāo)
選擇有效策略,求得給定關(guān)系表達(dá)式的值,使得查詢代價(jià)最?。▽?shí)際上是較?。?。實(shí)際系統(tǒng)的查詢優(yōu)化步驟實(shí)際系統(tǒng)的查詢優(yōu)化步驟1.將查詢轉(zhuǎn)換成某種內(nèi)部表示,通常是語法樹;2.根據(jù)一定的等價(jià)變換規(guī)則把語法樹轉(zhuǎn)換成標(biāo)準(zhǔn)(優(yōu)化)形式;3.選擇低層的操作算法,對(duì)于語法樹中的每一個(gè)操作:計(jì)算各種執(zhí)行算法的執(zhí)行代價(jià)選擇代價(jià)小的執(zhí)行算法4.生成查詢計(jì)劃(查詢執(zhí)行方案)查詢計(jì)劃是由一系列內(nèi)部操作組成的。
代價(jià)模型集中式數(shù)據(jù)庫(kù)單用戶系統(tǒng) 總代價(jià)=I/O代價(jià)+CPU代價(jià)多用戶系統(tǒng) 總代價(jià)=I/O代價(jià)+CPU代價(jià)+內(nèi)存代價(jià)分布式數(shù)據(jù)庫(kù)
總代價(jià)=I/O代價(jià)+CPU代價(jià)+內(nèi)存代價(jià)+通信代價(jià)
執(zhí)行策略1Q1=ПSname(бStudent.Sno=SC.Sno∧SC.Cno='2'(Student×SC))
①Student×SC(計(jì)算廣義笛卡兒積)讀取總塊數(shù)=讀Student表塊數(shù)+讀SC表遍數(shù)*每遍塊數(shù)
=1000/10+(1000/(10×5))×(10000/100)=100+20×100=2100
讀數(shù)據(jù)時(shí)間=2100/20=105秒執(zhí)行策略1(續(xù))
中間結(jié)果大小=1000*10000=107(1千萬條元組)
寫中間結(jié)果時(shí)間=10000000/10/20=50000秒
②б(選擇操作)
讀數(shù)據(jù)時(shí)間=50000秒
③П(投影操作)總時(shí)間=105+50000+50000秒=100105秒=27.8小時(shí)執(zhí)行策略2Q2=ПSname(бSC.Cno='2'(StudentSC))
①(計(jì)算自然連接) 讀取總塊數(shù)=2100塊 讀數(shù)據(jù)時(shí)間=2100/20=105秒 中間結(jié)果大小=10000(減少1000倍) 寫中間結(jié)果時(shí)間=10000/10/20=50秒
②б(讀取中間文件塊,做選擇操作)
讀數(shù)據(jù)時(shí)間=50秒
③П(把上一步結(jié)果投影輸出)總時(shí)間=105+50+50秒=205秒=3.4分
執(zhí)行策略3Q3=ПSname(StudentбSC.Cno='2'(SC))
①б(先對(duì)SC做選擇操作) 讀SC表總塊數(shù)=10000/100=100塊
讀數(shù)據(jù)時(shí)間=100/20=5秒
中間結(jié)果大小=50條不必寫入外存
②(讀Student,把讀入的元組與內(nèi)存中的SC元組連接) 讀Student表總塊數(shù)=1000/10=100塊
讀數(shù)據(jù)時(shí)間=100/20=5秒
③П(將連接結(jié)果投影輸出)總時(shí)間=5+5秒=10秒執(zhí)行策略4Q4=ПSname(StudentбSC.Cno='2'(SC))假設(shè)SC表在Cno上有索引,Student表在Sno上有索引①б(若SC表在Cno上有索引,則選擇讀取SC表中Cno=‘2’的50個(gè)元組即可)中間結(jié)果大小=50條不必寫入外存。②(若Student表在Sno上有索引,則僅讀取SC表中滿足條件的50個(gè)元組進(jìn)行連接操作即可)
③П(將結(jié)果投影輸出)總時(shí)間<10秒查詢優(yōu)化的一般準(zhǔn)則
選擇運(yùn)算應(yīng)盡可能先做
目的:減小中間關(guān)系在執(zhí)行連接操作前對(duì)關(guān)系適當(dāng)進(jìn)行預(yù)處理按連接屬性排序在連接屬性上建立索引
投影運(yùn)算和選擇運(yùn)算同時(shí)做目的:避免重復(fù)掃描關(guān)系將投影運(yùn)算與其前面或后面的雙目運(yùn)算結(jié)合目的:減少掃描關(guān)系的遍數(shù)查詢優(yōu)化的一般準(zhǔn)則(續(xù))某些選擇運(yùn)算+在其前面執(zhí)行的笛卡爾積===>連接運(yùn)算
例:бStudent.Sno=SC.Sno(Student×SC)
StudentSC提取公共子表達(dá)式舉例SELECTStudent.SnameFROMStudent,SCWHEREStudent.Sno=SC.SnoANDSC.Cno='2';查詢樹結(jié)果project(Sname)
select(SC.Cno=
2
)
join(Student.Sno=SC.Sno)
StudentSC舉例(續(xù))關(guān)系代數(shù)語法
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 銷售合同范本賣方
- 種苗銷售合同范本
- 佛山2025年廣東佛山市第二人民醫(yī)院服務(wù)中心工作人員招聘筆試歷年參考題庫(kù)附帶答案詳解
- 輪對(duì)加工合同范本
- 樂山2025年四川樂山師范學(xué)院招聘事業(yè)編制專職輔導(dǎo)員10人筆試歷年參考題庫(kù)附帶答案詳解
- hCAI-II-IN-10-生命科學(xué)試劑-MCE
- CRX-527-生命科學(xué)試劑-MCE
- 1-2-Dioleoyl-3-caprin-1-2-Dioleoyl-3-decanoyl-rac-glycerol-生命科學(xué)試劑-MCE
- 科技生活下的健康飲食與營(yíng)養(yǎng)搭配
- 香米購(gòu)買合同范本
- NB-T31056-2014風(fēng)力發(fā)電機(jī)組接地技術(shù)規(guī)范
- 部編版八年級(jí)上冊(cè)歷史期中復(fù)習(xí)重點(diǎn)總結(jié)
- DL5190.5-2019電力建設(shè)施工技術(shù)規(guī)范第5部分:管道及系統(tǒng)
- 農(nóng)信銀支付系統(tǒng)文檔
- 華為認(rèn)證HCIA-Security安全H12-711考試題庫(kù)及答案
- 建筑工地春節(jié)前安全教育
- (正式版)YST 1682-2024 鎂冶煉行業(yè)綠色工廠評(píng)價(jià)要求
- DL-T 5148-2021水工建筑物水泥灌漿施工技術(shù)條件-PDF解密
- JGJ6-2011 高層建筑筏形與箱形基礎(chǔ)技術(shù)規(guī)范
- 人工智能復(fù)習(xí)題(答案)及人工智能復(fù)習(xí)題與答案
- 桌游店創(chuàng)業(yè)計(jì)劃書
評(píng)論
0/150
提交評(píng)論