- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4.5 查询优化一般算法
本节主要讨论关系数据库中查寻优化的实现机理,从而得到查询优化的一般算法。
4.5.1 语法树
关系代数表达式的查询优化是由DBMS 的DML 编译器自动完成的。因此,查询优化
的基本前提就是需要将关系代数表达式转换为某种内部表示。常用的内部表示就是所谓的
关系代数语法树,简称为语法树。其实现的过程是先对一个关系代数表达式进行语法分析,
将分析结果用树的形式表达出来,此时的树就称之为语法树。语法树具有如下特征:
(1) 树中的叶结点表示关系。
(2) 树中的非叶结点表示操作。
有了语法树之后,再使用关系表达式的等价变换公式对于语法树进行优化变换,将原
始语法树变换为标准语法树(优化语法树) 。按照语法树的特征和查询优化的规则,语法树
变换的基本思想尽量使得选择运算和投影运算靠近语法树的叶端。
4.5.2 关系代数表达式优化算法
按照上述考虑,就有关系代数表达式的优化算法如下。
算法输入:关系代数表达式对应的语法树。
算法输出:计算该表达式的一个优化程序。
算法步骤:依次执行下述的每一步。
1. 应用选择运算串接公式和投影串接公式
使用选择串接公式将形如σF1∧∧Fn (E) 的表达式进行分解:
σ (E) ≡σ (σ (σ (E)) )
F 1∧∧Fn F1 F2 Fn
使用投影串接公式将形如Π … ( Π … (E)) 的表达式进行分解:
A1,A2, An B1,B2, Bm
∏A1,A2,…,An ( ∏B1,B2,…Bm (E)) ≡ ∏B1,B2,…,Bm (E)
其中{A1,A2,…,An}是{B1,B2,…,Bm}的子集。
这样做的目的是将选择或者投影运算串接成单个选择或者单个投影运算,以方便地和
有关二元运算进行交换与分配。
2. 应用选择运算和其他运算的交换公式与分配公式
这样做的目的是为了将选择运算尽量向下深入而靠近关系(即移至语法树的叶结点) 。
例如,利用选择和投影的交换公式将表达式转换为一个选择后紧跟一个投影,使得多
个选择、投影能同时执行或者能在一次扫描中完成。再例如,只要有可能,就要将σF(E1×E2)
转换为σ (E1)×E2 或E1×σ (E2),尽早执行基于值的选择运算可以减少对中间结果进行排序
F F
所花费的开销。
数据库理论及应用基础 33
3. 使用投影运算与其他运算的交换公式与分配公式
这样做的目的是将投影运算尽量向内深入靠近关系(即移至语法树叶结点) 。
具体做法是:
(1) 利用投影串接公式使得某些投影消解。
(2) 利用选择与投影的交换公式把单个投影分解成两个,其中一个先投影后选择的运
算(选择运算块)就可进一步向内深化。
4. 使用笛卡尔乘积与连接的转换公式
如果笛卡尔乘积之后还必须按连接条件进行选择操作,就将两者结合成连接运算。
5. 添加必要的投影运算
对每个叶结点添加必要的投影运算,用以消除对查询无用的属性。
6. 将关系代数语法树进行整形
通过上述步骤得到的语法树的内结点(非根结点和非叶结点)或者为一元运算结点,或
者为二元运算结点。对于三个二元运算“×、∪、-”中的每个结点来说,将剩余的一元运
算结点按照下面的方法进行分组。
(1) 如果一元运算结点σ或∏是该二元运算结点的父结点,则父结点与该点同组。
(2) 如果二元运算的子孙结点一直到叶结点都是一元运算 σ 或∏ ,则这些子孙结点与
该结点同组。
但是对于笛卡尔乘积来说,如果其子结点不是与它组合成等价连接的选择运算时,这
样的选择子结点不与该结点同组。
7. 由分组结果得到优化语法树
即一个操作序列,其中每一组结点的计算就是这个操作序列中的一步,各步的顺序是
任意的,只要保证任何一组不会在它的子孙组之前计算即可。
例4-3 对例4-1 中查询。
Q1 = ∏Sn
文档评论(0)