加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

详解Oracle数据库硬解析、软解析、软软解析联系与区别

发布时间:2019-10-19 01:02:52 所属栏目:编程 来源:波波说运维
导读:【大咖·来了 第7期】10月24日晚8点寓目《智能导购对话呆板人实践》 Oracle数据库硬理会和软理会有沟通的一步,而软软理会与硬理会、软理会完全纷歧样。 一、sql理会 这里我们先简朴sql语句执行步调: 语法搜查(syntax check) 语义搜查(symantic check): 对
副问题[/!--empirenews.page--] 【大咖·来了 第7期】10月24日晚8点寓目《智能导购对话呆板人实践》

Oracle数据库硬理会和软理会有沟通的一步,而软软理会与硬理会、软理会完全纷歧样。

一、sql理会

这里我们先简朴sql语句执行步调:

  • 语法搜查(syntax check)
  • 语义搜查(symantic check): 工具是否存在,是否有权限。
  • sql理会(parse): 操作内部算法对sql举办理会,天心理会树及执行打算。
  • 执行sql,返回功效(execute and return)

起宰衡识一下sql理会时用到的内存布局——shared pool。

shared pool是一块内存池,里边又被分成了许多小的区块,每个块有他们的浸染:

  • free (空闲)
  • library cache (库缓存,缓存sql语句以及sql所对应的执行打算)
  • row cache (字典缓存——库里有几多表,几多用户,几多个列,列的名字,列的数据范例,每个表多大等等都属于数据库自身信息。)

一个sql 语句,进入到数据库后,server process 会拿着sql语句到shared pool中的library cache 里边去找,看sql语句早年是否有执行过。也就是在library cache 内里看有没有这条sql语句以及sql语句所对应的执行打算。(此进程是通过对转达进来的SQL语句行使HASH函数运算得出HASH值,与共享池中现有语句的HASH值举办较量看是否逐一对应。现稀有据库中SQL语句的HASH值我们可以通过会见vsql、vsql、vsqlarea、v$sqltext等数据字典中的HASH_VALUE列查询得出。)

二、涉及理会的观念

1. 硬理会

硬理会(Hard Parse)是指Oracle在执行方针SQL时,在库缓存(Library Cache)中找不到可以重用的理会树和执行打算,而不得不从新开始理会方针SQL并天生响应的父游标(Parent Cursor)和子游标(Child Cursor)的进程。

硬理会现实上有两种范例:一种是在库缓存中找不到匹配的父游标(Parent Cursor),此时Oracle会从新开始理会方针SQL,新天生一个父游标和一个子游标,并把它们挂在对应的HashBucket中;其它一种是找到了匹配的父游标但未找到匹配的子游标,此时Oracle也会从新开始理会该方针SQL,新天生一个子游标,并把这个子游标挂在对应的父游标下。

硬理会进程:

  • 语法、语义及权限搜查;
  • 查询转换(通过应用各类差异的转换能力,会天生语义上等同的新的SQL语句,如count(1)会转为count(*));
  • 按照统计信息天生执行打算(找出本钱最低的路径,这一步较量耗时);
  • 将游标信息(执行打算)生涯到库缓存。

2. 软理会

软理会(Soft Parse)是指Oracle在执行方针SQL时,在Library Cache中找到了匹配的父游标(Parent Cursor)和子游标(Child Cursor),并将存储在子游标中的理会树和执行打算直接拿过来重用而无须从新开始理会的进程。

软理会进程:

  • 语法、语义及权限搜查;
  • 将整条SQL hash后从库缓存中执行打算。

软理会比拟硬理会省了三个步调。

3. 软软理会

软软理会(Soft Soft Parse)是指若参数SESSION_CACHED_CURSORS的值大于0,而且该会话游标所对应的方针SQL理会和执行的次数高出3次,则此时该会话游标会被直接缓存在当前会话的PGA中的。若该SQL再次执行的时辰,则只必要对其举办语法说明、权限工具说明之后就可以直接从当前会话的PGA中将之前缓存的匹配会话游标直接拿过来用就可以了,这就是软软理会。

软软理会进程:

要完全领略软软理会先要领略游标的观念,当执行SQL时,起主要打开游标,执行完成后,要封锁游标,游标可以领略为SQL语句的一个句柄。

在执行软软理会之前,起主要举办软理会,MOS上说执行3次的SQL语句会把游标缓存到PGA,这个游标一向开着,当再有沟通的SQL执行时,则跳过理会的全部进程直接去取执行打算。

三、尝试:

1. 情形筹备:

  1. drop table test purge; 
  2. alter system flush shared_pool; 
  3. create table test as select * from dba_objects where 1<>1; 
  4. exec dbms_stats.gather_table_stats(ownname => 'sys',tabname => 'test'); 

详解oracle数据库硬理会、软理会、软软理会接洽与区别

2. 硬理会

  1. select * from test where object_id=20; 
  2. select * from test where object_id=30; 
  3. select * from test where object_id=40; 
  4. select * from test where object_id=50; 

详解oracle数据库硬理会、软理会、软软理会接洽与区别

3. 软理会

  1. var oid number; 
  2. exec :oid:=20; 
  3. select * from test where object_id=:oid; 
  4. exec :oid:=30; 
  5. select * from test where object_id=:oid; 
  6. exec :oid:=40; 
  7. select * from test where object_id=:oid; 
  8. exec :oid:=50; 
  9. select * from test where object_id=:oid; 

详解oracle数据库硬理会、软理会、软软理会接洽与区别

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读