[2018年最新整理]DBMS_07查询编译器.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[2018年最新整理]DBMS_07查询编译器

第七章: 查询编译器 7.1 语法分析 语法分析与语法分析树 接收用类似SQL这样的语言编写的文本并将其转换成语法分析树 语法分析树的结点 原子,没有子结点 语法类 SQL的一个简单子集的语法 1 查询 Query ::= SFW Query ::= (Query) 2 Select-From-Where形式 SFW ::= SELECT SelList FROM FromList WHERE Condition 3 Select 列表 SelList ::= Attribute, SelList SelList ::= Attribute 4 From列表 FromList ::= Relation, FromList FromList ::= Relation 5 条件 Condition ::= Condition AND Condition Condition ::= Tuple IN Query Condition ::= Attribute = Attribute Condition ::= Attribute LIKE Pattern Tuple ::= Attribute 6 基本语法类 SQL Query with an Uncorrelated Subquery Find the movies with stars born in 1960 MovieStar(name, address, gender, birthdate) StarsIn(title, year, starName) SELECT title FROM StarsIn WHERE starName IN ( SELECT name FROM MovieStar WHERE birthdate LIKE ‘%1960’ ); Find the movies with stars born in 1960 MovieStar(name, address, gender, birthdate) StarsIn(title, year, starName) SELECT title FROM StarsIn, MovieStar WHERE (starName = name AND birthdate LIKE ‘%1960’); 预处理器 语义检查 检查关系的使用 检查与解析属性的使用 检查类型 合法语法树 7.2 用于改进查询计划的代数定律 交换律与结合律 R×S = S×R; (R×S)×T = R ×(S×T) R S = S R; (R S) T = R (S T) R∪S = S∪R; (R∪S)∪T = R∪(S∪T) R∩S = S∩R; (R∩S)∩T = R∩(S∩T) ?-连接满足交换律,如果所在位置有意义,则满足结合律。 涉及选择的定律 选择操作?对于查询优化非常关键。 分解律: ?C1 AND ?C2(R) = ?C1 (?C2(R) ) ?C1 OR ?C2(R) = (?C1 (R))∪S(?C2(R) )(只有R是集合时成立) ?C1 (?C2(R) )= ?C2 (?C1(R) ) ?对二元操作符进行下推:积、并、交、差和连接 对于并,选择必须下推到两个参数中 ?C (R∪S)=?C (R)∪ ?C (S) 对于差,选择必须下推到第一个参数中,下推到第二个参数是可选的 ?C (R - S)=?C (R) - S ?C (R - S)=?C (R) - ?C (S) 对于其它操作符,只要求下推到其中一个参数。 假设关系R具有C中提及的属性 ?C (R×S)=?C (R)×S 例 7.7 考虑关系R(a,b), S(b,c)及?(a=1 OR a=3) AND bc(R S) 下推选择 在某些情况下,首先选择尽可能往树的上部移动,然后下推。 例7.8 关系StarsIn(title, year, starName) Movie(title, year, length, studioName) 视图:CREATE VIEW MovieOf1996 AS SELECT * FROM Movie WHERE year = 1996; 即 ?year=1996(Movie) 查询:SELECT starName, studioName FROM MovieOf1996 NATURAL JOIN StarsIn; 涉及投影的定律 下推 投影列表中的项:E?x,则称E中的属性是投影的输入属性,x是输出属性。 简单投影:投影列表的属性构成不

文档评论(0)

liwenhua00 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档