ORACLE中 软解析与硬解析
来源:互联网 发布:中国电视网络电视台 编辑:程序博客网 时间:2024/05/17 22:42
ORACLE 软解析与硬解析
2009年01月21日 星期三 09:23
说到软解析(soft prase)和硬解析(hard prase),就不能不说一下Oracle对sql的处理过程。当你发出一条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的执行来说是开销昂贵的动作,所以,应当极力避免硬解析,尽量使用软解析。
这就是在很多项目中,倡导开发设计人员对功能相同的代码要努力保持代码的一致性,以及要在程序中多使用绑定
- ORACLE中 软解析与硬解析
- Oracle中的硬解析与软解析
- oracle软解析与硬解析
- Oracle 硬解析与软解析
- Oracle 硬解析与软解析
- Oracle 硬解析与软解析
- Oracle 硬解析与软解析
- Oracle 硬解析与软解析
- Oracle硬解析与软解析
- oracle 软解析与硬解析
- oracle 软解析 硬解析
- oracle硬解析、软解析、软软解析
- 【转】Oracle中的硬解析与软解析
- oracle性能调优之硬解析与软解析
- Oracle的硬解析和软解析
- Oracle的硬解析和软解析
- Oracle的硬解析和软解析
- oracle中的软解析和硬解析
- 【定期发布】全国土豆批发价格走势(单位:元/公斤) (截止至2010-10-14)
- IDFTP删除整个目录
- poj1066
- PE文件格式-1(PE文件与WINNT.H文件结构对照)
- 数据库启动过程
- ORACLE中 软解析与硬解析
- Linux常用命令(类似dos命令)
- Linux常用命令(linux特有命令)
- Linux常用命令(用户和用户组命令)
- Linux常用命令(压缩及解压命令)
- RPM的使用(软件的安装)
- linux下安装java
- Linux常用命令(系统命令)
- Spring 3 事务管理