当你发出一条 sql 语句交付 Oracle,在执行和获取结果前,Oracle 对此 sql 将进行几个步骤 的处理过程:

1、语法检查(syntax check)   检查此 sql 的拼写是否语法。

2、语义检查(semantic check)   诸如检查 sql 语句中的访问对象是否存在及该用户是否具备相应的权限。

3、对 sql 语句进行解析(prase)   利用内部算法对 sql 进行解析,生成解析树(parse tree)及执行计划(execution plan)。

4、执行 sql,返回结果(execute and return)   其中,软、硬解析就发生在第三个过程里。

Oracle 利用内部的 hash 算法来取得该 sql 的 hash 值,然后在 library cache 里查找是否存 在该 hash 值;   假设存在,则将此 sql 与 cache 中的进行比较;   假设“相同”,就将利用已有的解析树与执行计划,而省略了优化器的相关工作。这也 就是软解析的过程。   诚然,如果上面的 2 个假设中任有一个不成立,那么优化器都将进行创建解析树、生成 执行计划的动作。这个过程就叫硬解析。   创建解析树、生成执行计划对于 sql 的执行来说是开销昂贵的动作,所以,应当极力避 免硬解析,尽量使用软解析。   这 就 是 在 很 多 项 目 中 , 倡 导 开 发 设 计 人 员 对 功 能 相 同 的 代 码 要 努 力 保 持 代 码 的 一 致 性 , 以及要在程序中多使用绑定变量的原因。

查找不能被充分共享利用的SQL语句(查询LibraryCache中执行次数偏低的SQL语句): SELECT sql_text FROM v$sqlarea WHERE executions < 5 ORDER BY UPPER(sql_text);

查找SQL执行次数和SQL解析次数(hard parse),对比两个值的差: SELECT sql_text , parse_calls , executions FROM v$sqlarea ORDER BY parse_calls;

最新文章

  1. JSP自定义标签开发入门
  2. 简单介绍Javascript匿名函数和面向对象编程
  3. Java中类名与文件名的关系
  4. UIPickView 和 UIDatePicker
  5. cygwin chmod 失效
  6. QSS 样式表 (一)
  7. ural1682 Crazy Professor
  8. POJ 3928 &amp;amp; hdu 2492 &amp;amp; Uva1428 PingPong 【树状数组】
  9. C++:位操作基础篇之位操作全面总结
  10. Spring注解与Java元注解小结
  11. 在 CentOS 7上Virtualbox+phpVirtualBox完整虚拟化环境部署
  12. Future 示例
  13. 微信H5页面嵌入百度地图---解决手机的webKit定位,ios系统对非https网站不提供支持问题
  14. chmod语法
  15. ElasticSearch 例子
  16. 关于用户登录状态存session,cookie还是数据库或者memcache的优劣
  17. Singleton 单例模式 MD
  18. FocusBI:租房分析可视化(PowerBI网址体验)
  19. Qt + OpenSenceGraph(osg) 加载OSG模型
  20. 提示缺少python.h解决办法

热门文章

  1. 第三节:Redis缓存雪崩、击穿、穿透、双写一致性、并发竞争、热点key重建优化、BigKey的优化 等解决方案
  2. Python进程和线程实例详解
  3. org.junit.Assert(断言)
  4. Tkinter 吐槽之二:Event 事件在子元素中共享
  5. Centos7.5使用SSH密钥登录
  6. 一、.Net Core 依赖注入详解及Autofac使用
  7. web自动化之windows页面切换
  8. jdk keytool 自签证书
  9. SpringBoot | 1.2 全注解下的Spring IoC
  10. Extjs中由于ID重复引起的各种异常的解决方法