[20180828]关于参数cursor_space_for_time(10g).txt --//昨天测试session_cached_cursors不等于0的情况下,如果会话已经缓存了游标,这样即使其它语句消耗共享池, --//父子游标,父游标堆0,子游标,子游标堆0都没有清除,仅仅子游标堆6会被清除. --//今天补充测试cursor_space_for_time=true的情况.好像这个参数在10g之前还有效.因为11g以后使用metux来代替部分latch, --//不在支持此参数. 1.环境: SYS@test> @ &r/ver1 PORT_STRING VERSION BANNER ------------------------------ -------------- ---------------------------------------------------------------- x86_64/Linux 2.4.xx 10.2.0.4.0 Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 - 64bi SYS@test> show parameter cursor_space_for_time NAME TYPE VALUE --------------------- ------- ------- cursor_space_for_time boolean FALSE SYS@test> alter system set open_cursors=50000 scope=memory; System altered. --//建立测试脚本,仅仅分析sql语句,不执行.这样利用设定参数open_cursor=50000,消耗共享池内存. create table a1( id1 number,id2 number); $ cat ac.sql declare msql varchar2(500); mcur number; mstat number; begin for i in 1 .. 49000 loop mcur := dbms_sql.open_cursor; msql := 'select id1 from a1 where id2='||to_char(i); dbms_sql.parse(mcur,msql,dbms_sql.native); -- mstat := dbms_sql.execute(mcur); end loop; end; / 2.测试: --//cursor_space_for_time=false --//session 1: SCOTT@test> select * from dept where deptno=10; DEPTNO DNAME LOC ---------- -------------- ------------- 10 ACCOUNTING NEW YORK --//确定sql_id=4xamnunv51w9j,可以查询v$sql视图确定. --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000076B394C8 0000000076B396F0 select * from dept where deptno=10 1 0 0 0000000076B39408 00000000774C6FE8 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000076B396F0 0000000076B396F0 select * from dept where deptno=10 1 0 0 0000000076B39630 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//注意10.2.0.4版本也是一样,当前执行的sql语句KGLHDLMD=1.注意现在是cursor_space_for_time=FALSE的情况. --//session 1: SCOTT@test> select sysdate from dual; SYSDATE ------------------- 2018-08-28 09:17:30 --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000076B394C8 0000000076B396F0 select * from dept where deptno=10 0 0 0 0000000076B39408 00000000774C6FE8 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000076B396F0 0000000076B396F0 select * from dept where deptno=10 0 0 0 0000000076B39630 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//KGLHDLMD=0. --//补充测试: --//session 2: SYS@test> show parameter cursor_space_for_time NAME TYPE VALUE --------------------- ------- ------- cursor_space_for_time boolean FALSE --//session 1,执行多次缓存会话游标. select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select sysdate from dual; --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007672B290 000000007672B4B8 select * from dept where deptno=10 1 0 0 000000007672B1D0 00000000770A2190 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 000000007672B4B8 000000007672B4B8 select * from dept where deptno=10 1 0 0 000000007672B3F8 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//session 3: SCOTT@test> @ ac.sql declare * ERROR at line 1: ORA-04031: unable to allocate 576 bytes of shared memory ("shared pool","select job, nvl2(last_date, ...","sql area","ckydef : kkdlcky") ORA-06512: at "SYS.DBMS_SYS_SQL", line 909 ORA-06512: at "SYS.DBMS_SQL", line 39 ORA-06512: at line 9 --//等,报ora-04031错误!! --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007672B290 000000007672B4B8 select * from dept where deptno=10 1 0 0 000000007672B1D0 00 3664 0 1803 5467 5467 911274289 4xamnunv51w9j 0 父游标句柄地址 000000007672B4B8 000000007672B4B8 select * from dept where deptno=10 1 0 0 000000007672B3F8 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//父子游标句柄地址的KGLHDLMD=1. --//当会话缓存游标以后,在cursor_space_for_time=false的情况下.共享池内存不足时,并不能清除父子游标句柄地址,父游标堆0,子游标堆0.而子游标堆6的信息清除了. SYS@test> alter system flush shared_pool; System altered. SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007672B290 000000007672B4B8 select * from dept where deptno=10 0 0 1 00 00 0 0 1803 1803 1803 911274289 4xamnunv51w9j 0 父游标句柄地址 000000007672B4B8 000000007672B4B8 select * from dept where deptno=10 1 0 1 000000007672B3F8 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//父子游标句柄地址,父游标堆0都没有清除.并且注意父游标句柄地址的KGLHDLMD=1.其他KGLHDIVC=1表示什么不是很清楚. --//子游标堆0,子游标堆6清除. --//感觉10g与11g下alter system flush shared_pool;存在不同,10g下,仅仅父游标句柄地址的KGLHDLMD=1. --//而11g下,父子游标句柄地址的KGLHDLMD=1. 3.修改参数cursor_space_for_time看看: SYS@test> alter system set cursor_space_for_time=true scope=spfile; System altered. --//修改参数重启数据库.略. --//session 1: SCOTT@test> show parameter cursor_space_for_time NAME TYPE VALUE --------------------- ------- ----- cursor_space_for_time boolean TRUE SCOTT@test> select * from dept where deptno=10; DEPTNO DNAME LOC ---------- -------------- ------------- 10 ACCOUNTING NEW YORK --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007773EC58 00000000777521F0 select * from dept where deptno=10 1 2 0 000000007773BE60 000000007773C1C8 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 00000000777521F0 00000000777521F0 select * from dept where deptno=10 1 0 0 0000000077752130 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//对比前面的情况可以发现KGLHDLMD=1外,子游标句柄地址的KGLHDPMD=2.KGLHDPMD表示library cahce pin模式. --//KGLHDLMD表示library cache lock模式. 1=null,2=共享模式 3=独占模式. --//session 1: SCOTT@test> select sysdate from dual; SYSDATE ------------------- 2018-08-28 09:24:34 --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007773EC58 00000000777521F0 select * from dept where deptno=10 0 0 0 000000007773BE60 000000007773C1C8 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 00000000777521F0 00000000777521F0 select * from dept where deptno=10 0 0 0 0000000077752130 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//当前sql语句<>'4xamnunv51w9j'时,KGLHDLMD=0. --//session 1,执行多次缓存会话游标. select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select sysdate from dual; --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 000000007773EC58 00000000777521F0 select * from dept where deptno=10 1 0 0 000000007773BE60 000000007773C1C8 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 00000000777521F0 00000000777521F0 select * from dept where deptno=10 1 0 0 0000000077752130 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//KGLHDLMD=1. 4.执行测试脚本: --//session 1: SCOTT@test> alter system set open_cursors=50000 scope=memory; System altered. --//退出再进入,不然不会生效: --//session 2: SYS@test> alter system flush shared_pool; System altered. --//注:前面的测试我在session 1执行ac.sql前退出过1次(要使alter system set open_cursors=50000 scope=memory;生效), --//导致sql_id='4xamnunv51w9j'游标已经退出回话缓存,虽然我又执行多次缓存该游标,但是不应该在该回话调用ac.sql. --//这样测试有点问题.要缓存游标的这个回话不要退出.重来测试. --//session 1: select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select * from dept where deptno=10; select sysdate from dual; --//不退出. --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000072C7CDD8 0000000071E6E388 select * from dept where deptno=10 1 0 0 0000000071E4A7C0 0000000071E65C80 3664 8088 1803 13555 13555 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000071E6E388 0000000071E6E388 select * from dept where deptno=10 1 0 0 0000000071E1C618 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//KGLHDLMD=0. --//session 3: SCOTT@test> @ ac.sql --//等,报ora-04031错误!! declare * ERROR at line 1: ORA-04031: unable to allocate 144 bytes of shared memory ("shared pool","select type#,blocks,extents,...","Typecheck","coldef: qcopCreateCol") ORA-06512: at "SYS.DBMS_SYS_SQL", line 909 ORA-06512: at "SYS.DBMS_SQL", line 39 ORA-06512: at line 9 --//session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000072C7CDD8 0000000071E6E388 select * from dept where deptno=10 1 0 0 0000000071E4A7C0 00 3664 0 1803 5467 5467 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000071E6E388 0000000071E6E388 select * from dept where deptno=10 1 0 0 0000000071E1C618 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//我感觉与会话缓存游标一样,父子游标的KGLHDLMD=1. --//当会话缓存游标以后,在cursor_space_for_time=true的情况下.共享池内存不足时,并不能清除父子游标句柄地址,父游标堆0,子游标堆0.而子游标堆6的信息清除了. --//刷新共享池看看. --//session 2: SYS@test> alter system flush shared_pool; System altered. SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000072C7CDD8 0000000071E6E388 select * from dept where deptno=10 0 0 1 00 00 0 0 1803 1803 1803 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000071E6E388 0000000071E6E388 select * from dept where deptno=10 1 0 1 0000000071E1C618 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 --//父子游标句柄地址,父游标堆0都没有清除.并且注意父游标句柄地址的KGLHDLMD=1.其他KGLHDIVC=1表示什么不是很清楚. --//子游标堆0,子游标堆6清除. --//感觉10g与11g下alter system flush shared_pool;存在不同,10g下,仅仅父游标句柄地址的KGLHDLMD=1. --//而11g下,父子游标句柄地址的KGLHDLMD=1. --//session 1退出后,session 2: SYS@test> @ &r/sharepool/shp4 4xamnunv51w9j 0 TEXT KGLHDADR KGLHDPAR C40 KGLHDLMD KGLHDPMD KGLHDIVC KGLOBHD0 KGLOBHD6 KGLOBHS0 KGLOBHS6 KGLOBT16 N0_6_16 N20 KGLNAHSH KGLOBT03 KGLOBT09 -------------- ---------------- ---------------- ---------------------------------------- ---------- ---------- ---------- ---------------- ---------------- ---------- ---------- ---------- --------- ---------- ---------- ------------- ---------- 子游标句柄地址 0000000072C7CDD8 0000000071E6E388 select * from dept where deptno=10 0 0 1 00 00 0 0 1803 1803 1803 911274289 4xamnunv51w9j 0 父游标句柄地址 0000000071E6E388 0000000071E6E388 select * from dept where deptno=10 0 0 1 0000000071E1C618 00 2812 0 0 2812 2812 911274289 4xamnunv51w9j 65535 总结: 感觉设置cursor_space_for_time=true与session_cached_cursors差别不大,不做比较,总之无法彻底清除干净从共享池. 测试还是乱,
[20180828]关于参数cursor_space_for_time(10g).txt
来源:这里教程网
时间:2026-03-03 11:56:46
作者:
编辑推荐:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- Oracle 12C Data Gurad RAC TO RAC
Oracle 12C Data Gurad RAC TO RAC
26-03-03 - 从 Oracle 转型 MySQL 分布式事务数据库的实战旅途
从 Oracle 转型 MySQL 分布式事务数据库的实战旅途
26-03-03 - Oracle 18c安装初体验
Oracle 18c安装初体验
26-03-03 - word2010怎么设置双行合一
word2010怎么设置双行合一
26-03-03 - 数据库服务:activemq 在灾备双活建设中的研究
数据库服务:activemq 在灾备双活建设中的研究
26-03-03 - 删除归档日志报RMAN-08137
删除归档日志报RMAN-08137
26-03-03 - SQL优化案例-分区索引之无前缀索引(六)
SQL优化案例-分区索引之无前缀索引(六)
26-03-03 - Debian服务端口绑定配置详解(手把手教你如何在Debian系统中正确绑定和配置服务端口)
- buffer busy waits引起的会话突增
buffer busy waits引起的会话突增
26-03-03 - Check FRA usage
Check FRA usage
26-03-03
