- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
通过分析执行计划优化SQL;
Agenda :
SQL语句执行的过程
如何产生执行计划
如何分析执行计划
如何干预执行计划
;
SQL语句执行的过程
;处理SELECT:
语法分析:
搜索同一语句
检查语法、对象名和权限
锁定语法分析过程中使用的对象
创建和存储执行计划
绑定:获取变量值
执行:处理语句
提取:将结果行返回用户进程 ;处理 DML 语句: 语法分析:与处理查询时的语法分析阶段相同。绑定:与处理查询时的绑定阶段相同。执行: 如果数据库缓冲区高速缓存中不存在某些数据块和还???块,服务器进程就从数据文件将它们读入数据库缓冲区高速缓存。服务器进程锁定要进行修改的行.还原块用于存储数据的前像以便在需要时回退 DML 语句。数据块记录数据的新值。服务器进程将数据的前像记录到回退块中,并更新数据块。这两种更改都是在数据库缓冲区高速缓存中进行的。数据库缓冲区高速缓存中所有已更改的块都标记为灰数据缓冲区,即与磁盘中相应的块不同的缓冲区。DELETE 或 INSERT 命令的处理使用类似的步骤。 DELETE 命令的前像包含已删除行中的列值,而 INSERT 命令的前像中包含行的位置信息。 ;处理 DDL 语句:
DDL(数据定义语言)语句的执行与 DML(数据操纵语言)语句和查询的执行不尽相同,因为成功执行 DDL 语句需要对数据字典具有写权限。对于这些语句,语法分析阶段实际上包括分析、数据字典查找和执行。;共享sql语句 ??? 为了不重复解析相同的SQL语句(因为解析操作比较费资源,会导致性能下降),在第一次解析之后,ORACLE将SQL语句及解析后得到的执行计划存放在内存中。这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享。因此,当你执行一个SQL语句(有时被称为一个游标)时,如果该语句和之前的执行过的某一语句完全相同,并且之前执行的该语句与其执行计划仍然在内存中存在,则ORACLE就不需要再进行分析,直接得到该语句的执行路径。ORACLE的这个功能大大地提高了SQL的执行性能并大大节省了内存的使用。使用这个功能的关键是将执行过的语句尽可能放到内存中,所以这要求有大的共享池(通过设置shared buffer pool参数值)和尽可能的使用绑定变量的方法执行SQL语句。 ??? 当你向ORACLE 提交一个SQL语句,ORACLE会首先在共享内存中查找是否有相同的语句。这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须完全相同(包括空格,换行等)。;下面是判断SQL语句是否与共享内存中某一SQL相同的步骤: 1). 对所发出语句的文本串进行hashed。如果hash值与已在共享池中SQL语句的hash值相同,则进行第2步: ?2)? 将所发出语句的文本串(包括大小写、空白和注释)与在第1步中识别的所有 ??????? 已存在的SQL语句相比较。 ??????? 例如: ??????? SELECT * FROM emp WHERE empno = 1000; ??????? 和下列每一个都不同 ??????? SELECT * from emp WHERE empno = 1000; ??????? SELECT * FROM EMP WHERE empno = 1000; ??????? SELECT * FROM emp WHERE empno = 2000; ??????? 在上面的语句中列值都是直接SQL语句中的,这类sql称为硬编码SQL ??????? ? ??????? 使用绑定变量的SQL语句中必须使用相同的名字的绑定变量(bind variables) , 例如: ??????? a. 该2个sql语句被认为相同 ??????? select pin , name from people where pin = :blk1.pin; ??????? select pin , name from people where pin = :blk1.pin; ??????? b. 该2个sql语句被认为不相同 ??????? select pin , name from people where pin = :blk1.ot_ind; ??????? select pin , name from people where pin = :blk1.ov_ind; ??????? 今后我们将上面的这类语句称为绑定变量SQL。 ??????? ;? 3). 将所发出语句中涉及的对象与第2步中识
文档评论(0)