SQL语句执行过程说明

上一篇 / 下一篇  2016-04-22 17:08:10

下述内容摘自一名资深性能测试大拿分享的文档,此人,深藏功与名,留才不留名,所以楼主就不点名了,大家共同学习一下就好。

一条SQL语句的执行要经过以下过程:

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

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

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

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

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

Oracle利用内部的hash算法来取得该sqlhash值,然后在library cache里查找是否存在该hash值;假设存在,则将此sqlcache中的进行比较;假设"相同",就将利用已有的解析树与执行计划,而省略了优化器的相关工作。这也就是软解析的过程。

如果上面的2个假设中任有一个不成立,那么优化器都将进行创建解析树、生成执行计划的动作。这个过程就叫硬解析。

创建解析树、生成执行计划对于sql的执行来说是开销昂贵的动作,所以,应当极力避免硬解析,尽量使用软解析。使用软解析的话就要求SQL语句要尽量绑定变量。


TAG:

 

评分:0

我来说两句

日历

« 2024-03-27  
     12
3456789
10111213141516
17181920212223
24252627282930
31      

数据统计

  • 访问量: 73525
  • 日志数: 55
  • 建立时间: 2016-04-19
  • 更新时间: 2020-09-23

RSS订阅

Open Toolbar