开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1669|回复: 3
收起左侧

[其它数据库例题] SQL性能优化详细讲解

[复制链接]

结帖率:61% (35/57)
发表于 2013-5-4 13:06:08 | 显示全部楼层 |阅读模式   海南省海口市

当一个用户与数据库建立了连接后,会向数据库发出操作请求,也就是向数据库送过去一条(或是几条或一个PL/SQL包)SQL语句。Oracle在接到这条SQL之后,首先会将这个SQL做一个Hash函数运算,得到一个Hash值,然后到共享池中寻找是否有和这个Hash值匹配的SQL存在。如果找到了,Oracle将直接使用已经存在的SQL的执行计划去执行当前的SQL,然后将结果返回给用户。如果在共享池中没有找到相同Hash值的SQL,Oracle会认为这是一条新的SQL,将会按照下面的顺序来执行:    a.语法分析
    主要看这条SQL是否符合Oracle规定的语法规则,如果发现语法有误,将向用户抛出一个错误信息。
    b.语义分析
    当语法分析通过以后,Oracle将对这条SQL做一些对象、权限方面的检查,查看SQL中操作的表是否存在,表中的列是否正确,用户是否有操作这个对象的权限等。
    c.生成执行计划
    这个过程Oracle将通过一系列的操作,来做出最后SQL的执行计划,比如查看操作对象的统计信息,动态采样等。
    d.SQL的执行
    Oracle按照上一步生成的执行计划,实际地执行SQL语句,并将结果返回给用户。至此,一条SQL语句执行完毕。
    对于OLTP系统来说,相同的SQL重复频率非常高,如果优化器反复解析SQL,必然极大地消耗系统资源;另外,OLTP系统用户请求的结果集都非常小, 所以基本上都会考虑使用索引,那么既然大家的执行计划都一致,为什么要对SQL做重复分析呢?bind peeking在第一次获得了一个正确的执行计划之后,后续的所有SQL都按照这个执行计划来执行,可以极大地改善系统的性能,这是由OLTP系统的特性 决定的。
    对于OLAP系统,他的SQL执行计划和谓词的值关系极大,谓词的值不同,很可能执行计划就不同,如果都采用相同的执行计划,SQL的执行效率必然非常 低;另外,一个OLAP系统数据库每天执行的SQL数量远远比OLTP少,并且SQL的重复率远远低于OLTP,这种情况下,SQL
    解析花费的代价和SQL的执行花费的代价来比,完全可以忽略。
    因此,对于OLAP系统,我觉得不需要做变量绑定,这样做可能发生执行计划选择错误的严重后果。另外,如果事实上的确做了变量绑定,bing peeking也只能保证第一条硬分析的SQL能够选择正确的执行计划,如果后面的谓词变量改变,很可能还是会出现SQL选择错误的执行计划,因此在 OLAP系统中,不要绑定变量。


发表于 2013-11-29 08:02:25 | 显示全部楼层   江苏省盐城市
写的不错!!!!!!!!!!
回复 支持 反对

使用道具 举报

发表于 2013-11-20 06:59:11 | 显示全部楼层   江苏省盐城市
学习一下!!!!!!!!
回复 支持 反对

使用道具 举报

结帖率:37% (7/19)
发表于 2013-5-12 10:35:31 | 显示全部楼层   北京市北京市
沙发 哈哈        
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表