了解oracle对sql的处理过程

本文深入探讨了Oracle在处理SQL语句时的四个关键步骤:语法检查、语义检查、解析以及执行SQL并返回结果。重点阐述了软、硬解析的概念及其在优化SQL执行效率中的作用。

Oraclesql的处理过程

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

1、语法检查(syntax check)                                                                                        

检查此sql的拼写是否语法。                                                                                        

2、语义检查(semantic check)                                                                                      

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

3、对sql语句进行解析(parse)                                                                                       

利用内部算法对sql进行解析,生成解析树(parsetree)及执行计划(execution plan)

其中软、硬解析就发生在第三个过程里。                                                                           

Oracle利用内部的hash算法来取得该sqlhash值,然后在librarycache里查找是否存在该hash值;假设存在,则将此sqlcache中的进行比较 假设相同,就将利用已有的解析树与执行计划,而省略了优化器的相关工作。这也就是软解析的过程。 如果上面的2个假设中任有一个不成立,那么优化器都将进行创建解析树、生成执行计划的动作。这个过程就叫硬解析。创建解析树、生成执行计划对于sql的执行来说是开销昂贵的动作,所以,应当极力避免硬解析,尽量使用软解析。                                       

4、执行sql,返回结果(executeand return)                                                                          

        

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值