网站大量收购独家精品文档,联系QQ:2885784924

数据库系统实现_06.ppt

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库系统实现_06

第六章  查询执行 1.一种查询代数 2.物理查询计划操作符介绍 3.数据库操作的一趟算法 4.嵌套循环连接 5.基于排序的两趟算法 6.基于散列的两趟算法 7.基于索引的算法 8.缓冲区管理 9.使用超过两趟的算法 引言 主要任务: 1)对使用诸如SQL的某种语言所写的查询进行语法分析,也即将 查询语句 转换成按某种有用方式表示查询语句结构的语法树. 2)将语法分析树转换成关系代数表达式树(或某种类似标记形 式),也称为逻辑查询计划 3)逻辑查询计划转换为物理查询计划: a)指明要执行的操作 b)找出这些操作执行的顺序 c)执行每步所用的算法 d)获得所存储数据的方法 e)数据从一个操作传递到另一个操作的方式 查询处理器的主要组成部分: 查询 查询计划 元数据 数据 DBMS处理查询计划的过程是这样的: 在做完查询语句的词法、语法检查之后,将语句提交给DBMS的查询优化器,优化器做完代数优化和存取路径的优化之后,由预编译模块对语句进行处理并生成查询规划,然后在合适的时间提交给系统处理执行,最后将执行结果返回给用户。 在实际的数据库产品(如Oracle、Sybase等)的高版本中都是采用基于代价的优化方法,这种优化能根据从系统字典表所得到的信息来估计不同的查询规划的代价,然后选择一个较优的规划。 虽然现在的数据库产品在查询优化方面已经做得越来越好,但由用户提交的SQL语句是系统优化的基础,很难设想一个原本糟糕的查询计划经过系统的优化之后会变得高效,因此用户所写语句的优劣至关重要。 DBMS中的存储统计信息: 有关关系的统计信息 关系R中的元组数目 含有关系R的元组的块数目 关系R中每个元组的字节数 关系R的块因子,即一个块中能存放的关系 统计信息的维护 ?? 每次关系修改时,更新统计信息 ?? 系统处于轻负载时,更新统计信息 查询处理的步骤: 分析: 例:SELECT SNAME FROM S,C,SC WHERE S.SNO=SC.SNO AND C.CNO=SC.CNO AND C.CNAME=‘DATABASE SYSTEM’ S=10000,C=1000,SC=100000 查询方案: 1) ∏ sname(σ S.SNO=SC.SNO AND((sXc)Xsc)) C.CNO=SC.CNO AND C.CNAME=‘DATABASE SYSTEM) 2) ∏ sname(σC.CNAME=‘DATABASE SYSTEM ((s∞c) ∞sc)) 3) ∏ sname( ((s∞ σC.CNAME=‘DATABASE SYSTEM (c)) ∞sc)) 1.一种基于包的查询代数 包与集合的区别:包是多重集 SQL关系与集合的区别: 1)关系是包 2)关系有模式 1.并,交和差: 2.选择操作符: 3.投影操作符: 4.关系的积: 5.连接操作: 6.消除重复: 7.分组和聚集: 8.排序操作符: 9.表达式树: 1.并,交和差: 基于包的并,交和差的语义: 1)R∪S:一个元组t在结果中出现的次数是在R中出现的次数与S中出      现的次数之和. 2)R∩S:一个元组t在结果中出现的次数是在R中出现的次数与S中出      现的次数之间的最小值. 3)R-S:一个元组t在结果中出现的次数是在R中出现的次数减去S中      现的次数. 例:如果R={A,B,B},S={C,A,B,C}是两个包   那么:   1)R∪S= 2)R∩S= 3)R-S= 考虑:S={C,A,B,B,C}时,   2.选择操作符:   σc(R)产生由R中满足条件C的元组构成的包,结果关系的模式与R的模式一样.  例: 3.投影操作符:  ∏L(R)是R

文档评论(0)

82393aa + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档