open_cursors 参数控制单个session 打开的cursor的数量。
v$open_cursor 是所有session(打开的cursor)的总和。
session_cached_cursors 指一个session可以缓存多少个cursor,让后续相同的SQL语句不再打开游标,从而避免软解析的过程来提高性能,是软软解析的关键所在。
设置pga端的cache list的长度,当session_cached_cursors设置为0时,pga的cache list长度为0,这时候当sga中的cursor关闭的时候它相关的library cache handle的lock位被清0,从v$open_cursor里看不到这个被关闭的cursor,它服从于shared pool的lru机制,当shared pool需要新的buffer空间时,它将会被flush出shared pool。当session_cached_cursors设置为非0值时,pga的cache
list长度为session_cached_cursors值的大小,同时pga cache list将会保留一份拷贝,这时候即使sga中的cursor关闭的时候它相关的library cache handle始终被加了null mode lock,当shared pool空间紧张时library cache handle始终将会被保留在shared pool中,而新的应用访问这个cursor的时候会直接去自己的pga cache list里面搜索。
1 > opened cursors current (当前单个session打开的cursors数量)
2 > parse count (hard) (当前session硬解析次数)
3 > parse count (total) (当前session解析总次数)
4 > session cursor cache count (设置session_cached_cursors参数后,"相同"sql被解析3次后被cache在sessioncursor cache中的数量
5 > session cursor cache hits (软软解析的次数 a "softer" soft parse)
6 > 手工计算一下软解析次数parse count (total) - session cursor cache hits - parse count (hard)= parse count(soft)
如何正确设置session_cached_cursors参数
正确设置open_cursors和'session_cached_cursors' 可以减少sql解析,提高系统性能,那么,如何正确设置'session_cached_cursors'这个参数呢?我们可以把握下面的原则:
1、'session_cached_cursors'数量要小于open_cursors,设置方法:
open_cursors:该参数含义是同一个session同时打开最多在使用的游标数。
在Oracle10.2.0.1.0版本中默认为300;
session_cached_cursors:session_cached_cursors就是说的是一个session可以缓存多少个cursor,让后续相同的SQL语句不再打开游标,从而避免软解析的过程来提高性能。(绑定变量是解决硬解析的问题),软解析同硬解析一样,比较消耗资源.所以这个参数非常重要。
在Oracle10.2.0.1.0版本中默认为20
在oracle 9.2.0.1.0里修改会报下面的错,这是9i版本的一个bug,可先在init文件里改好,再修改spfile文件。
SQL> alter system set session_cached_cursors=20 scope=spfile;
ORA-02096: 此选项的指定初始化参数不可修改
2、要考虑共享池的大小
3、使用下面的sql判断'session_cached_cursors' 的使用情况。如果使用率为100%则增大这个参数值。
4、调整参数后进行测试。
使用session cursor caching功能后,与soft parsing基本做相同的工作,但因为减少检索库高速缓冲区的时间,因此有助于减少library cache 锁存器争用。Session cursorcaching 功能上一个注意事项是此功能只在会话级上有效。因此每次执行 sql 过程中,如果要进行logon和logoff时,虽然使用此项功能但是并不能从中受益。所以应该尽量利用连接池技术,维持会话连接,这样才有助于提升性能。
整理自网络
分享到:
相关推荐
Oracle 参数 open_cursors 与 session_cached_cursors 详解 Oracle 数据库中,open_cursors 和 session_cached_cursors 是两个重要的参数,它们对 Oracle 的运行性能产生了直接的影响。本文将详细解释这两个参数的...
这些参数包括 session_cached_cursors、session_max_open_files、sessions、license_max_sessions、license_sessions_warning 和 processes。 在解决这个问题之前,我们需要了解这些参数的含义: * session_cached...
修改`open_cursors`和`session_cached_cursors`的参数值 - **命令行调整方法**: - 查看当前设置:`SQL> show parameter cursors` - 调整`open_cursors`的值:`SQL> alter system set open_cursors=1500 scope=...
同时,监测session_clilshl_cache_hits以调整session_cached_cursors和open_cursors参数。数据字典缓冲区的命中率同样重要,通过V$cache视图检查并调整分配内存。 除此之外,文章还提到了SQL级别的调整,这是四级...
3. `session_cached_cursors`:这个参数指定Oracle服务器为每个会话缓存的预编译游标数量。缓存游标有助于提高性能,因为它减少了编译SQL语句的次数。然而,它也会占用`OPEN_CURSORS`的配额。 `cursor_space_for_...
* `SESSION_CACHED_CURSORS`:设置会话缓存游标的数量,以提高数据库的性能。 * `AUDIT_TRAIL`:设置审计跟踪,以确保数据库的安全。 * `RECYCLEBIN`:设置回收站,以避免回收站过大。 * `LOG_ARCHIVE_DEST_1`:设置...
6. **session_cached_cursors** 和 **open_cursors**: 控制会话缓存的游标数和允许打开的游标数,优化游标管理可以减少磁盘I/O并提升性能。 7. **open_links** 和 **open_links_per_instance**: 设定单个会话可打开...
绑定变量相关的参数,例如cursor_sharing(光标共享)、OPEN_CURSORS(打开光标数)、SESSION_CACHED_CURSORS(会话缓存光标数)也是优化的一部分。 优化器相关的参数,包括optimizer_index_caching(索引缓存优化...
Shared Pool Statistics提供了关于共享池的信息,包括共享池的使用情况、游标数量(如SESSION_CACHED_CURSORS、OPEN_CURSORS)等。共享池的管理对于减少SQL语句解析和提高系统响应时间至关重要。 ##### 6. SQL ...
比如,通过调整OPEN_CURSORS参数限制打开的游标数量,减少SESSION_CACHED_CURSORS以节省内存,或者启用CURSOR_SPACE_FOR_TIME以根据使用频率决定是否保存游标。 此外,监控和使用报告如V$SGASTAT可以帮助识别SGA各...
16. **SESSION_CACHED_CURSORS**:预分配的游标数,减少打开和关闭游标的开销。 17. **CURSOR_SPACE_FOR_TIME**:控制游标空间的生命周期,以提高性能。 18. **SGA_MAX_SIZE**:设置系统全局区域(SGA)的最大大小...
当Shared Pool碎片化严重时,可能导致ORA-04031错误,表现为SQL语句无法获取足够的内存空间,此时可能需要调整SQL语句的复用策略、监控open_cursors和session_cached_cursors参数,以及定期进行Shared Pool的清理。...
session_cached_cursors integer 0 session_max_open_files integer 10 sessions integer 225 shared_server_sessions integer ``` **作用:** - 显示当前数据库实例中的 session 相关参数设置。 ##### 2. 修改 ...
*.session_cached_cursors=100 *.sga_target=500m *.shared_pool_size=100m *.undo_management='AUTO' *.undo_retention=0 *.undo_tablespace='UNDOTS1' *.user_dump_dest='/home/oracle/admin/bipdb/udump' ``` ...
11. 修改其他高级初始化参数,如Audit_trail设为none,Open_cursors设为3000,Sec_case_sensitive_logon设为false,Session_cached_cursors设为200,Undo_retention设为1800秒。 12. 确认设置无误后,点击“下一步”...
- 设置其他参数:例如`shared_pool_size`、`cursor_sharing`、`cursor_space_for_time`、`open_cursors`、`session_cached_cursors`和`pre_page_sga`等参数,这些参数的调整有助于优化Oracle性能。 - **重启...
- `V$SESSION_CURSOR_CACHED` 显示当前会话的游标使用情况。 通过分析这些视图,可以了解游标的状态、使用频率和内存占用,帮助进行游标管理优化。 总之,Oracle游标调优涉及多个方面,包括内存分配策略、游标复用...
4. Open Cursors:提高并发连接数,增加open_cursors和session_cached_cursors的值。 5. 审计:若无审计需求,将`audit_trail`设为none,减少不必要的资源消耗。 6. 异步I/O:启用异步I/O(filesystemio_options设为...
说明: 与 NLS_TIME_TZ_FORMAT 相似, 其中的一对值指定 TIMESTAMP 数据类型的默认值, 该类型除存储 YEAR, MONTH 和 DAY 日期值, HOUR, MINUTE 和 SECOND 时间值, 还存储 TIMEZONE_HOUR 和 TIMEZONE_MINUTE。...
- 根据监控结果,调整数据库参数如`open_cursors`和`sessiorL cached_cursors`以减少软解析,提高性能。 6. **优化效果**: - 参数调整后,数据库性能得到提升,如导入操作不再卡顿,I/O消耗减少,缓存命中率和硬...