- 1、本文档共89页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据库第八章 的关系数据库查询优化
8.4 物理优化 代数优化改变查询语句中操作的次序和组合,不涉及底层的存取路径 对于一个查询语句有许多存取方案,它们的执行效率不同, 仅仅进行代数优化是不够的 物理优化就是要选择高效合理的操作算法或存取路径,求得优化的查询计划 物理优化(续) 选择的方法: 基于规则的启发式优化 基于代价估算的优化 两者结合的优化方法 基于启发式规则的存取路径选择优化 一、 选择操作的启发式规则 二、 连接操作的启发式规则 基于启发式规则的存取路径选择优化(续) 一、 选择操作的启发式规则: 1. 对于小关系,使用全表顺序扫描,即使选择列上有索引 对于大关系,启发式规则有: 2. 对于选择条件是主码=值的查询 查询结果最多是一个元组,可以选择主码索引 一般的RDBMS会自动建立主码索引。 基于启发式规则的存取路径选择优化(续) 3. 对于选择条件是非主属性=值的查询,并且选择列上有索引 要估算查询结果的元组数目 如果比例较小(10%)可以使用索引扫描方法 否则还是使用全表顺序扫描 基于启发式规则的存取路径选择优化(续) 4. 对于选择条件是属性上的非等值查询或者范围查询,并且选择列上有索引 要估算查询结果的元组数目 如果比例较小(10%)可以使用索引扫描方法 否则还是使用全表顺序扫描 基于启发式规则的存取路径选择优化(续) 5. 对于用AND连接的合取选择条件 如果有涉及这些属性的组合索引 优先采用组合索引扫描方法 如果某些属性上有一般的索引 则可以用索引扫描方法 否则使用全表顺序扫描。 6. 对于用OR连接的析取选择条件,一般使用全表顺序扫描 基于启发式规则的存取路径选择优化(续) 二、 连接操作的启发式规则: 1. 如果2个表都已经按照连接属性排序 选用排序-合并方法 2. 如果一个表在连接属性上有索引 选用索引连接方法 3. 如果上面2个规则都不适用,其中一个表较小 选用Hash join方法 基于启发式规则的存取路径选择优化(续) 4. 可以选用嵌套循环方法,并选择其中较小的表,确切地讲是占用的块数(b)较少的表,作为外表(外循环的表) 。 理由: 设连接表R与S分别占用的块数为Br与Bs 连接操作使用的内存缓冲区块数为K 分配K-1块给外表 如果R为外表,则嵌套循环法存取的块数为Br+( Br/K-1)Bs 显然应该选块数小的表作为外表 8.5 sql语句优化 目标 有利于DBMS选择代价最小的查询执行计划 依据 DBMS优化器支持的优化策略 8.5 sql语句优化 Sql语句一般优化策略 充分利用索引 尽量避免表搜索 减少不必要的运算 8.5 sql语句优化 1. 搜索参数化 带有=、<、>、>=、<=等操作符的条件查询就可以直接使用索引 。如: id = T0001,salary>30000,a = 1 and c = 7。 下列则不是搜索参数: salary = commission,dept != 10,salary *12 >= 30000,age21 8.5 sql语句优化 在查询中可以提供一些冗余的搜索参数,使优化器有更多的选择余地。如title和titleauthor两张表是一对多的关系,同样的查询条件我们有以下三种表现方法: ●SELECT title_id, title FROM titles, titleauthor WHERE title.title_id = titleauthor.title_id AND titleauthor.title_id = ‘T81002 ●SELECT title_id, title FROM titles, titleauthor WHERE title.title_id = titleauthor.title_id AND title.title_id = ‘T81002 ●SELECT title_id, title FROM titles, titleauthor WHERE title.title_id = titleauthor.title_id AND title.title_id = ‘T81002 AND titleauthor.title_id = ‘T81002 三种方法一种比一种要好,因为后者为优化器提供了更多的选择机会。 8.4 sql语句优化 2.避免使用不兼容的数据类型 SELECT name FROM employee WHERE salary > 60000 3. IS?NULL?与?IS?NOT?NULL 在where子句中使用is?null或is?not?null的语句优化器
您可能关注的文档
- 数字化校园示范工程的项目进展的报告.doc
- 数字信号处理—基于计算机的方法2014cph9IIR的设计.ppt
- 数字化的环境论文学习生活方式论文.doc
- 数字化装配的发展现状的研究.doc
- 数字娱乐产品的设计之硬盘MP4的设计.doc
- 数字城管建设的项目建议书.doc
- 数字媒体技术专业数字印刷媒体课程的设计指导书.doc
- 数字式秒表文档的资料.doc
- 数字式调频收音机的设计的资料.doc
- 数字推理题的解题的技巧大全.doc
- DeepSeek培训课件入门宝典:第2册 开发实战篇 .pptx
- 全面认识全过程人民民主-2024春形势与政策课件.pptx
- 2024春形势与政策-全面认识全过程人民民主.pptx
- 2025年春季学期形势与政策第二讲-中国经济行稳致远讲稿.docx
- 2024春形势与政策-铸牢中华民族共同体意识课件.pdf
- 2024春形势与政策-走好新时代科技自立自强之路课件 (2).pptx
- 2024春形势与政策-走好新时代科技自立自强之路课件.pptx
- 形势与政策学习指导教学-整套课件.pdf
- 2023年春季形势与政策讲稿第三讲-开创高质量发展新局面.pdf
- DeepSeek培训课件-清华大学-DeepSeek模型本地部署与应用构建.pptx
最近下载
- 2024年常州信息职业技术学院单招职业技能测试题库及答案解析.docx VIP
- 便利店企业商业计划书-完整版本.docx
- 水利水电工程建筑专业-渡槽设计(全套图纸).doc
- 开学第一课(校园防欺凌).pptx
- 镇环境卫生整治方案.ppt
- 2025-2030年中国供应链行业市场运行格局及前景战略研判报告.docx
- 2024交流发电机定子VPI绝缘规范6.3kV少胶定子条式线圈(F级).pdf
- 广告市场调查与统计分析基本概念课件.ppt
- 武汉市2025届高中毕业生二月调研考试(二调)数学试卷(含答案详解).pdf
- 2024年广东省佛山市南海区初中毕业生适应性学业检测(一)英语试题(PDF版有答案).pdf
文档评论(0)