06第六章关系系统及其优化new.ppt
《06第六章关系系统及其优化new.ppt》由会员分享,可在线阅读,更多相关《06第六章关系系统及其优化new.ppt(51页珍藏版)》请在三一办公上搜索。
1、第六章:关系系统及其查询优化,关系系统的定义和分类查询处理关系系统中的查询优化,关系系统的定义,关系系统:支持关系数据模型的数据库管理系统(粗略)关系系统(确切定义):一个系统可以定义为一个关系系统,当且仅当它:支持关系数据库支持选择、投影和连接运算(自然连接),对这些运算不要求定义任何物理存取路径,关系系统的分类,许多关系系统的产品按E.F.Codd的思想将关系系统分为:表式系统(a)最小关系系统(b)关系完备的系统(c)全关系系统(d),S,M,I,S,M,I,S,M,I,S,M,I,a,b,c,d,S:StructureI:IntegrityM:Manipulation,关系数据模型,集
2、合级,关系系统的查询处理,查询处理的步骤:,查询,关系代数表达式,执行计划,查询结果输出,数据,基于数据的统计分析,优 化 器,分析器&翻译器,评 价 引 擎,DBMS,为什么需要查询优化?,一个查询实例:求选修2号课程的学生姓名SQL表示:select Snamefrom Students,SCwhere Students.Sno=SC.Sno and Cno=2;关系代数表示:Q1=sname(Students.Sno=SC.Sno and Cno=2(StudentsSC)Q2=sname(Cno=2(Students SC)Q3=sname(Students Cno=2(SC),代价计
3、算 Q1代价计算(仅考虑I/O代价)计算广义笛卡尔积代价假定:在内存中,存放5块Students元组和一块SC元组,一块可以装10个Students元组或100个SC元组.假定:Students有1000个元组,SC有10000个元组,其中选2号课程的有50个元组数据只有读到内存才能进行连接,Q1=sname(Students.Sno=SC.Sno and Cno=2(StudentsSC),10,100,SC,Students,5块,通过读取块数计算I/O代价 读取块数计算方法:Students 1000个元组 SC 10000个元组读取总块数:若每秒读写20块,则花费:,Q1=sname(
4、Students.Sno=SC.Sno and Cno=2(StudentsSC),Student块数,SC读入内存的次数,SC块数,10,100,SC,Students,5块,条件:Students 1000个元组,SC 10000个元组迪卡尔集后的元组个数为:103 104=107连接后的中间结果内存放不下,需暂时写到外存若每块可装10个完成迪卡尔集后的元组,则写这些元组需:(107/10)/20=5 104s选择操作:读回需5 104s,假设选择后剩50个元组,均可放在内存投影操作:只需CPU时间查询共花费:105+2 5 104 105 s 28小时,Q1=sname(Students
5、.Sno=SC.Sno and Cno=2(StudentsSC),每秒读20块,Q2=sname(Cno=2(Students SC),Q2代价计算(仅考虑I/O代价)计算自然连接代价也要把数据读到内存进行连接,但连接结果比笛卡尔积要小得多读取块数依然为:花费为2100/20105s假设连接结果大小为104个元组,写到外存需:(104/10)/20=50s,每秒读20块,Q2=sname(Cno=2(Students SC)Q3=sname(Students Cno=2(SC),读取自然连接结果,执行选择运算,需50s,选择结果均可放在内存投影运算:只需CPU时间总花费为:105+50+50
6、=205s 3.4分钟Q3代价计算(仅考虑I/O代价)计算对SC做选择运算的代价需读SC到内存进行选择运算读SC块数为:10000/100=100花费为:100/20=5s选择结果为50个SC元组,均可放在内存,Q3=sname(Students Cno=2(SC),计算和Students自然连接的 代价需读Students到内存进行连 接运算读Students块数为:1000/10=100花费为:100/20=5s连接结果为50个元组,均可放在内存投影运算:只需CPU时间总花费:5+5=10s,10,50,SC,Students,5块,关系系统的查询优化,关系系统的查询优化由系统完成,而不是
7、由用户完成优化器可以从数据字典获取许多统计信息如果数据库的物理统计信息改变了,优化器可以对查询进行重新优化以选择适应的执行计划优化器可以考虑数百种不同的执行计划优化器包括了许多复杂的技术优化目标:寻求最优的执行计划,使查询执行开销尽量小,查询执行开销主要包括:总代价=I/O代价+CPU代价多用户数据库执行开销:总代价=I/O代价+CPU代价+内存代价查询优化的途径代数优化物理优化,关系系统的查询优化,代数优化,查询优化的一般步骤将查询转化成内部表示-语法树根据等价变化规则,将语法树转化成优化形式选择底层操作算法生成查询计划,代数优化,查询优化的一般准则(启发式规则):下面的优化策略一般能提高查
8、询效率,但不一定是最优的选择和投影运算尽可能先做,降低中间结果大小把投影运算和选择运算同时进行 sno(cno=2(SC)把投影和其前或后的双目运算结合起来 Cname(Course SC)把某些选择同在它前面要执行的笛卡尔积结合起来成为一个连接运算 Students.Sno=SC.Sno and Cno=2(StudentsSC)找出公共子表达式,代数优化,关系代数等价变换规则:给定sname(Students.Sno=SC.Sno and Cno=2(StudentsSC)如何将上述提到的运算先做,即得到:sname(Students Cno=2(SC)规则1:连接、笛卡尔积的交换律 E1
9、 E2 E2 E1 E1 E2=E2 E1 E1 E2=E2 E1 E:关系代数表达式 F:连接条件,代数优化,规则2:连接、笛卡尔积的结合律(E1 E2)E3=E1(E2 E3)(E1 E2)E3 E1(E2 E3)(E1 E2)E3 E1(E2 E3)规则3:投影的串接定律 A1,A2,.,An(B1,B2,.,Bn(E)A1,A2,.,An(E),F1,F2,F1,F2,代数优化,规则4:选择的串接定律 F1(F2(E)F1F2(E)规则5:选择和投影的交换律 F(A1,A2,.,An(E)=A1,A2,.,An(F(E)特殊情况 A1,A2,.,An(F(E)A1,A2,.,An(F(
10、A1,A2,.,An,B1,B2,.,Bm(E),代数优化,规则6:选择与笛卡尔积的交换律 F(E1 E2)F(E1)E2 F仅和E1有关 F(E1 E2)F1(E1)F2(E2)F=F1F2 F(E1 E2)F2(F1(E1)E2)F1-E1 F2-E1E2规则7:选择与并的分配律 F(E1 E2)F(E1)F(E2),代数优化,规则8:选择与差的分配律 F(E1-E2)F(E1)-F(E2)规则9:选择对自然连接的分配律 F(E1 E2)F(E1)F(E2),代数优化,规则10:投影与笛卡尔积的分配律 A1,A2,.,An,B1,B2,.,Bm(E1 E2)A1,A2,.,An(E1)B1
11、,B2,.,Bm(E2)规则11:投影与并的分配律 A1,A2,.,An(E1 E2)A1,A2,.,An(E1)A1,A2,.,An(E2),代数优化,关系代数表达式的优化算法:应用关系代数等价变换规则来优化关系代数表达式,使优化后的表达式能遵循查询优化的一般准则,在语法树上进行优化,代数优化,关系代数表达式的优化算法输入:语法树输出:计算关系代数表达式的程序 1 利用规则4把形如F1F2Fn(E)变换成 F1(F2(Fn(E).)2 对每一个选择,利用规则49尽可能移到树的叶端 3 对于每个投影,利用规则3,5,10,11尽可能移到树的叶端 4 利用规则35把选择和投影的串接合并成单个选择
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 06 第六 关系 系统 及其 优化 new
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-5825174.html