微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

oracle11g新特性--result cache结果高速缓存

oracle 11g新加入了结果缓存特性,包括服务器结果高速缓存和客户机高速缓存.服务器结果高速缓存又包括SQL查询结果高速缓存和pl/sql函数结果高速缓存.它适合数据库查询频繁执行并且查询依赖的表数据变化频率很低的情况.

以下是一些result_cache的说明:

sql中通过/*+ result_cache*/提示实现result cache,pl/sql函数通过建函数时的result_cache子句实现.使用result cache的sql在执行计划上会有result cache操作符.
dbms_result_cache包,可以监视和管理result cache.
例如:dbms_result_cache.flush:清除result cache.
dbms_result_cache.invalidate(owner,name):使某对象的result cache无效.
dbms_result_cache.status:显示result cache的状态.
dbms_result_cache.memory_report:显示result cache的内存使用状况.
v$result_cache_*视图,是和result cache存相关.
例如:
v$result_cache_statistics:显示result cache的设置和统计数据.
v$result_cache_objects:显示result cache中的对象和对象状态.
v$result_cache_memory:显示result cache的内存统计数据.
数据库参数:
result_cache_mode:认manual,只能在sql中通过/*+ result_cache*/提示实现result cache.auto根据执行频率,执行成本和对象的变化频率等因素等自动result cache.force只要result cache合理,会缓存所有查询结果.
result_cache_max_size:result cache是SGA share pool的一部分,由参数result_cache_max_size控制其大小,认memory_target的0.25%或者sga_target的0.5%或者shared_pool_size的1%,但最大不能超过share pool的75%.
result_cache_max_reslut:认5,即5%,单条SQL查询结果最大占用result_cache_max_size的比例.result_cache_remote_expiration:认0.指定远程数据库查询结果涉及的表保证多久不变的时间,此参数一般只适合用于只读的表或周期性更改的表,否则会影响本地库调用时的正确性.

原文地址:https://www.jb51.cc/oracle/206335.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐