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.指定远程数据库查询结果涉及的表保证多久不变的时间,此参数一般只适合用于只读的表或周期性更改的表,否则会影响本地库调用时的正确性.

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...