關(guān)系查詢處理和查詢優(yōu)化_第1頁
關(guān)系查詢處理和查詢優(yōu)化_第2頁
關(guān)系查詢處理和查詢優(yōu)化_第3頁
關(guān)系查詢處理和查詢優(yōu)化_第4頁
關(guān)系查詢處理和查詢優(yōu)化_第5頁
已閱讀5頁,還剩26頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

關(guān)系查詢處理和查詢優(yōu)化第一頁,共三十一頁,2022年,8月28日第九章

關(guān)系查詢處理及其查詢優(yōu)化9.1關(guān)系數(shù)據(jù)庫系統(tǒng)的查詢處理9.2關(guān)系數(shù)據(jù)庫系統(tǒng)的查詢優(yōu)化9.3代數(shù)優(yōu)化

---關(guān)系代數(shù)表達式的優(yōu)化9.4物理優(yōu)化

---存取路徑和底層操作算法的選擇第二頁,共三十一頁,2022年,8月28日9.1關(guān)系數(shù)據(jù)庫系統(tǒng)的查詢處理查詢處理的任務(wù):是把用戶提交給RDBMS的查詢語句轉(zhuǎn)換為高效的執(zhí)行計劃.查詢處理步驟查詢分析查詢檢查查詢優(yōu)化查詢執(zhí)行第三頁,共三十一頁,2022年,8月28日查詢處理步驟:詞法分析語法分析語義分析符號名轉(zhuǎn)換安全性檢查完整性檢查查詢樹代數(shù)優(yōu)化物理優(yōu)化等執(zhí)行策略描述代碼生成查詢計劃的執(zhí)行代碼查詢語句數(shù)據(jù)庫數(shù)據(jù)字典查詢分析查詢檢查查詢優(yōu)化查詢執(zhí)行第四頁,共三十一頁,2022年,8月28日實現(xiàn)查詢操作的算法示例一、選擇操作的實現(xiàn)例1SELECT*FROMStudentWHERE<條件表達式>;

<條件表達式>:C1:無條件

C2:Sno=‘200215121’;

C3:Sage>20;

C4:Sdept=‘CS’ANDSage>20;1、簡單的全表掃描方法順序掃描,逐一檢查每個元組是否滿足選擇條件,把滿足條件的元組作為結(jié)果輸出。適合:小表2、索引(或散列)掃描方法如果條件表達式的屬性上有索引(如B+樹索引或Hash索引),通過索引先找到滿足條件的元組主碼或元組指針,再通過元組指針直接在查詢的基本表中找到元組。如C2:第五頁,共三十一頁,2022年,8月28日二、連接操作的實現(xiàn)例2SELECT*FROMStudent,SCWHEREStudent.Sno=SC.Sno;1、嵌套循環(huán)方法(nestedloop)簡單。對外層循環(huán)Student的每一個元組,檢查內(nèi)層循環(huán)SC中的每一個元組,并檢查連接屬性是否相等2、排序-合并方法(sort-mergejoin)常用,適合有序表步驟:若沒排序,首先對Student、SC按連接屬性Sno排序;取Student第一個Sno,一次掃描SC中具有相同Sno元組,連接起來;當掃描到SC中第一個不相同Sno元組時,返回Student掃描下一個元組,在掃描SC中具有相同Sno元組,把它們連接起來;重復(fù)上述步驟,直到Student掃描完。第六頁,共三十一頁,2022年,8月28日二、連接操作的實現(xiàn)3、索引連接法在SC上建立屬性Sno索引;對Student的每一個元組,由Sno值通過索引查找相應(yīng)SC元組;把這些SC元組和Student元組連接起來;循環(huán)執(zhí)行②③,直到Student元組處理完。4、HashJoin方法把連接屬性作為Hash碼,用同一個Hash函數(shù)把R和S中的元組散列到同一個Hash文件中;第一步,劃分階段,對小表R進行一遍處理,把它的元組按Hash函數(shù)分散到Hash表的桶中;(假設(shè):R完全裝入內(nèi)存)第二步,試探階段(連接階段),對表S進行一遍處理,把它的元組散列到適當?shù)腍ash桶中,并把元組與來自R并與之匹配的元組連接起來。第七頁,共三十一頁,2022年,8月28日9.2關(guān)系數(shù)據(jù)庫系統(tǒng)的查詢優(yōu)化9.2.1查詢優(yōu)化概述查詢優(yōu)化的必要性查詢優(yōu)化極大地影響RDBMS的性能。查詢優(yōu)化是RDBMS關(guān)鍵技術(shù)、關(guān)系系統(tǒng)的優(yōu)點(關(guān)系系統(tǒng):支持表結(jié)構(gòu)、選擇連接(自然)操作)查詢優(yōu)化的可能性關(guān)系表達式語義的級別很高,使DBMS可以從關(guān)系表達式中分析查詢語義。第八頁,共三十一頁,2022年,8月28日由DBMS進行查詢優(yōu)化的好處用戶不必考慮如何最好地表達查詢以獲得較好的效率系統(tǒng)可以比用戶程序的優(yōu)化做得更好(1)優(yōu)化器可以從數(shù)據(jù)字典中獲取許多統(tǒng)計信息,而用戶程序則難以獲得這些信息(2)如果數(shù)據(jù)庫的物理統(tǒng)計信息改變了,系統(tǒng)可以自動對查詢重新優(yōu)化以選擇相適應(yīng)的執(zhí)行計劃。在非關(guān)系系統(tǒng)中必須重寫程序,而重寫程序在實際應(yīng)用中往往是不太可能的(3)優(yōu)化器可以考慮數(shù)百種不同的執(zhí)行計劃,而程序員一般只能考慮有限的幾種可能性。(4)優(yōu)化器中包括了很多復(fù)雜的優(yōu)化技術(shù)第九頁,共三十一頁,2022年,8月28日

代價模型

集中式數(shù)據(jù)庫 總代價=I/O代價+CPU代價+內(nèi)存代價分布式數(shù)據(jù)庫

總代價=I/O代價+CPU代價+內(nèi)存代價+通信代價

查詢優(yōu)化的總目標:選擇有效策略,求得給定關(guān)系表達式的值,使得查詢代價最小。第十頁,共三十一頁,2022年,8月28日9.2.2一個實例例:求選修了課程C2的學(xué)生姓名

SELECTStudent.Sname FROMStudent,SC WHEREStudent.Sno=SC.SnoANDSC.Cno='2';假設(shè)1:外存:

Student:1000條,SC:10000條,選修2號課程:50條假設(shè)2:一個內(nèi)存塊裝元組:10個Student,或100個SC或10個連接結(jié)果元組;內(nèi)存中一次可以存放:5塊Student元組,1塊SC元組假設(shè)3:讀寫速度:20塊/秒假設(shè)4:連接方法:基于數(shù)據(jù)塊的嵌套循環(huán)法第十一頁,共三十一頁,2022年,8月28日執(zhí)行策略1Q1=ПSname(бStudent.Sno=SC.Sno∧SC.Cno='2'(Student×SC))

①Student×SC

讀取總塊數(shù)=讀Student表塊數(shù)+讀SC表遍數(shù)*每遍塊數(shù)

=1000/10+(1000/(10×5))×(10000/100)=100+20×100=2100

讀數(shù)據(jù)時間=2100/20=105秒中間結(jié)果大小=1000*10000=107(1千萬條元組)

寫中間結(jié)果時間

=10000000/10/20=50000秒

②б

讀數(shù)據(jù)時間

=50000秒

③П

總時間=105+50000+50000秒=100105秒=27.8小時第十二頁,共三十一頁,2022年,8月28日執(zhí)行策略2Q2=ПSname(бSC.Cno='2'(StudentSC))①

讀取總塊數(shù)=2100塊 讀數(shù)據(jù)時間=2100/20=105秒 中間結(jié)果大小

=10000(減少1000倍) 寫中間結(jié)果時間

=10000/10/20=50秒

②б

讀數(shù)據(jù)時間=50秒

③П

總時間=105+50+50秒=205秒=3.4分

第十三頁,共三十一頁,2022年,8月28日執(zhí)行策略3Q2=ПSname(StudentбSC.Cno='2'(SC))

①б

讀SC表總塊數(shù)=10000/100=100塊

讀數(shù)據(jù)時間=100/20=5秒

中間結(jié)果大小=50條不必寫入外存

② 讀Student表總塊數(shù)=1000/10=100塊

讀數(shù)據(jù)時間=100/20=5秒

③П

總時間=5+5秒=10秒第十四頁,共三十一頁,2022年,8月28日執(zhí)行策略4Q2=ПSname(StudentбSC.Cno='2'(SC))假設(shè)SC表在Cno上有索引,Student表在Sno上有索引

①б

讀SC表索引 讀SC表總塊數(shù)

=50/100<1塊 讀數(shù)據(jù)時間

中間結(jié)果大小=50條不必寫入外存② 讀Student表索引=讀Student表總塊數(shù)=50/10=5塊 讀數(shù)據(jù)時間③П

總時間<10秒第十五頁,共三十一頁,2022年,8月28日9.3代數(shù)優(yōu)化代數(shù)優(yōu)化:基于關(guān)系代數(shù)等價變換規(guī)則的優(yōu)化方法關(guān)系代數(shù)表達式等價指用相同的關(guān)系代替兩個表達式中相應(yīng)的關(guān)系所得到的結(jié)果是相同的第十六頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)等價變換規(guī)則設(shè)E1、E2等是關(guān)系代數(shù)表達式,F(xiàn)是條件表達式

l.連接、笛卡爾積交換律

E1×E2≡E2×E1 E1E2≡E2E1 E1FE2≡E2FE1

2.連接、笛卡爾積的結(jié)合律

(E1×E2)×E3≡E1×(E2×E3)(E1E2)E3≡E1(E2E3)(E1E2)E3≡E1(E2E3)

F1

F2

F1

F23.投影的串接定律

π

A1,A2,

,An(π

B1,B2,,Bm(E))≡π

A1,A2,,An(E)假設(shè):1)E是關(guān)系代數(shù)表達式

2)Ai(i=1,2,…,n),Bj(j=l,2,…,m)是屬性名

3){A1,A2,…,An}構(gòu)成{Bl,B2,…,Bm}的子集0第十七頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)等價變換規(guī)則(續(xù))4.選擇的串接定律

бF1

(б

F2(E))≡бF1∧F2(E)選擇的串接律說明選擇條件可以合并這樣一次就可檢查全部條件。5.選擇與投影的交換律(1)假設(shè):選擇條件F只涉及屬性A1,…,AnбF(πA1,A2,,An(E))≡πA1,A2,,An(бF(E))

(2)假設(shè):F中有不屬于A1,…,An的屬性B1,…,BmπA1,A2,,An

(

бF(E))≡πA1,A2,,An(бF

(πA1,A2,,An,B1,B2,,Bm(E)))第十八頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)等價變換規(guī)則(續(xù))6.選擇與笛卡爾積的交換律(1)假設(shè):F中涉及的屬性都是E1中的屬性

бF(E1×E2)≡бF(E1)×E2

(2)假設(shè):F=F1∧F2,并且F1只涉及E1中的屬性,

F2只涉及E2中的屬性 則由上面的等價變換規(guī)則1,4,6可推出:

бF(E1×E2)≡бF1(E1)×бF2(E2)

(3)假設(shè):F=F1∧F2,

F1只涉及E1中的屬性,

F2涉及E1和E2兩者的屬性

бF(E1×E2)≡бF2(бF1(E1)×E2)

它使部分選擇在笛卡爾積前先做

第十九頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)等價變換規(guī)則(續(xù))7.選擇與并的交換 假設(shè):E=E1∪E2,E1,E2有相同的屬性名

бF(E1∪E2)≡бF(E1)∪бF(E2)

8.選擇與差運算的交換 假設(shè):E1與E2有相同的屬性名бF(E1-E2)≡бF(E1)-бF(E2)9.投影與笛卡爾積的交換

假設(shè):E1和E2是兩個關(guān)系表達式,

A1,…,An是E1的屬性,

B1,…,Bm是E2的屬性πA1,A2,…,An,B1,B2,…,Bm(E1×E2)≡πA1,A2,…,An(E1)×πB1,B2,…,Bm(E2)l0.投影與并的交換

假設(shè):E1和E2有相同的屬性名

πA1,A2,…,An(E1∪E2)≡πA1,A2,…,An(E1)∪πA1,A2,…,An(E2)第二十頁,共三十一頁,2022年,8月28日查詢樹的啟發(fā)式優(yōu)化啟發(fā)式規(guī)則:選擇運算應(yīng)盡可能先做

目的:減小中間關(guān)系投影運算和選擇運算同時做目的:避免重復(fù)掃描關(guān)系將投影運算與其前面或后面的雙目運算結(jié)合目的:減少掃描關(guān)系的遍數(shù)某些選擇運算+在其前面執(zhí)行的笛卡爾積==>連接運算例:бStudent.Sno=SC.Sno(Student×SC)

StudentSC

找出公共子表達式(如:視圖定義表達式)第二十一頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)表達式的優(yōu)化算法

算法:關(guān)系表達式的優(yōu)化輸入:一個關(guān)系表達式的查詢樹。輸出:優(yōu)化的查詢樹。方法:(1)分解選擇運算利用規(guī)則4把形如бF1∧F2∧…∧Fn(E)變換為

бF1(бF2(…(бFn(E))…))(2)通過交換選擇運算,將其盡可能移到葉端對每一個選擇,利用規(guī)則4~8盡可能把它移到樹的葉端。(3)通過交換投影運算,將其盡可能移到葉端

對每一個投影利用規(guī)則3,9,l0,5中的一般形式盡可能把它移向樹的葉端。

第二十二頁,共三十一頁,2022年,8月28日關(guān)系代數(shù)表達式的優(yōu)化算法

(續(xù))(4)合并串接的選擇和投影,以便能同時執(zhí)行或在一次掃描中完成利用規(guī)則3~5把選擇和投影的串接合并成單個選擇、單個投影或一個選擇后跟一個投影。使多個選擇或投影能同時執(zhí)行,或在一次掃描中全部完成盡管這種變換似乎違背“投影盡可能早做”的原則,但這樣做效率更高。

(5)對內(nèi)結(jié)點分組把上述得到的語法樹的內(nèi)節(jié)點分組。每一雙目運算(×,,∪,-)和它所有的直接祖先為一組(這些直接祖先是б,π運算)。如果其后代直到葉子全是單目運算,則也將它們并入該組,但當雙目運算是笛卡爾積(×),而且其后的選擇不能與它結(jié)合為等值連接時除外。把這些單目運算單獨分為一組。

(6)生成程序生成一個程序,每組結(jié)點的計算是程序中的一步。各步的順序是任意的,只要保證任何一組的計算不會在它的后代組之前計算。

第二十三頁,共三十一頁,2022年,8月28日例題例:求選修了課程C2的學(xué)生姓名

SELECTStudent.Sname FROMStudent,SC WHEREStudent.Sno=SC.SnoANDSC.Cno='2';第二十四頁,共三十一頁,2022年,8月28日語法樹結(jié)果project(Sname)

select(SC.Cno=2)

join(Student.Sno=SC.Sno)

StudentSC關(guān)系代數(shù)語法樹πSname

SC.Cno=’2’

Student.Sno=SC.S

×

StudentSC第二十五頁,共三十一頁,2022年,8月28日利用優(yōu)化算法把語法樹轉(zhuǎn)換成標準(優(yōu)化)形式πSname

Student.Sno=SC.Sno

SC.Cno=2

×

StudentSCπSname

SC.Cno=2

StudentSC第二十六頁,共三十一頁,2022年,8月28日9.4物理優(yōu)化:選擇低層的存取路徑代數(shù)優(yōu)化改變查詢語句中操作的次序和組合,不涉及底層的存取路徑物理優(yōu)化就是要選擇高效合理的操作算法或存取路徑,求得優(yōu)化的查詢計劃,達到查詢優(yōu)化的目標。方法:基于規(guī)則的啟發(fā)式優(yōu)化基于代價估算的優(yōu)化兩者結(jié)合的優(yōu)化方法基于啟發(fā)式規(guī)則的存取路徑優(yōu)化一、選擇操作的啟發(fā)式規(guī)則二、連接操作的啟發(fā)式規(guī)則第二十七頁,共

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論