Heim  >  Artikel  >  Datenbank  >  Oracle数据库SQL语句的执行过程

Oracle数据库SQL语句的执行过程

WBOY
WBOYOriginal
2016-06-07 17:32:401171Durchsuche

SQL语句在数据库中处理过程是怎样的呢?执行顺序呢?在回答这个问题前,我们先来回顾一下:在ORACLE数据库系统架构下,SQL语句由

SQL语句在数据库中处理过程是怎样的呢?执行顺序呢?在回答这个问题前,我们先来回顾一下:在Oracle数据库系统架构下,SQL语句由用户进程产生,然后传到相对应的服务端进程,之后由服务器进程执行该SQL语句,如果是SELECT语句,服务器进程还需要将执行结果回传给用户进程。

SQL语句的执行过程一般如下:

解析(PARSE)—— 绑定(BIND)——执行(EXECUTE)——提取(FETCH 只有SELECT才需要这步)

Oracle数据库SQL语句的执行过程

 

解析

 

服务器进程接收到一个SQL语句时,首先要将其转换成执行这个SQL语句的最有效步骤,这些步骤被称为执行计划。

Step 1:检查共享池中是否有之前解析相同的SQL语句后所存储的SQL文本、解析树和执行计划。如果能从共享池的缓存库中找到之前解析过生成的执行计划,则SQL语句则不需要再次解析,便可以直接由库缓存得到之前所产生的执行计划,从而直接跳到绑定或执行阶段,这种解析称作软解析。

但是如果在共享池的库缓存中找不到对应的执行计划,则必须继续解析SQL、生成执行计划,,这种解析称作硬解析

在缓存池解析过的SQL,会有一个对应的哈希值与之对应,你可以通过V$SQL视图来查询,请看下面一个例子:

 

SCOTT.DEPT WHERE DEPTNO =10; SQLSCOTT.DEPT WHERE DEPTNO =20; SQL> SELECT HASH_VALUE , ADDRESS, EXECUTIONS ,SQL_TEXT 2 FROM V$SQL ; HASH_VALUE ADDRESS EXECUTIONS SQL_TEXT 27EE4B7C SCOTT.DEPT 27EEA3BC SCOTT.DEPT WHERE DEPTNO =10

 

 

下面我们先清空共享池缓存的执行计划,然后使用绑定变量,查看执行计划的变换

 

 

SQL> ALTER SYSTEM FLUSH SHARED_POOL; System altered SQL> VARIABLE deptno NUMBER; SQL; PL/SQL procedure successfully completed deptno SQLSCOTT.DEPT WHERE DEPTNO=:deptno; DEPTNO DNAME LOC ACCOUNTING NEW YORK SQL; PL/SQL procedure successfully completed deptno SQLSCOTT.DEPT WHERE DEPTNO=:deptno; DEPTNO DNAME LOC RESEARCH DALLAS SQL> SELECT HASH_VALUE , ADDRESS, EXECUTIONS ,SQL_TEXT 2 FROM V$SQL ; HASH_VALUE ADDRESS EXECUTIONS SQL_TEXT 27D2BA1C SCOTT.DEPT WHERE DEPTNO=:deptno 

Step 2:语法分析,分析SQL语句的语法是否符合规范,衡量语句中各表达式的意义

Step 3:检查是否存在语义错误和权限。语义分析,检查语句中设计的所有数据库对象是否存在,且用户有相应的权限。

Step 4:视图转换和表达式转换 将涉及视图的查询语句转换为相应的对基表查询语句。将复杂表达式转化较为简单的等效连接表达式。

Step 5:决定最佳执行计划。优化器会生成多个执行计划,在按统计信息带入,找出执行成本最小的执行计划,作为执行此SQL语句的执行计划

Step 6:将SQL文本、解析树、执行计划缓存到库缓存,存放地址以及SQL语句的哈希值。

更多详情请继续阅读第2页的内容

Oracle体系结构系列相关文章:

Oracle体系结构之SCN、实例恢复

Oracle体系结构之检查点

Oracle体系结构之SQL语句的执行过程

linux

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn