我正在使用 Oracle Database 11g 版本 11.2.0.2.0 并尝试启用 oci 客户端缓存。它不工作。我为启用它所做的配置更改是 -
- 通过将服务器端参数“client_result_cache_size”设置为 10485760 (10 MB) 来启用客户端结果集缓存
- 设置上述参数后重启oracle实例
- 通过执行语句 ALTER TABLE emp RESULT_CACHE (MODE FORCE) 添加了表注释。我验证了注释是通过稍后查询用户表来应用的。
- 在客户端(即 JDBC 驱动程序)上启用语句缓存。
- 使用准备好的语句来执行查询,以便启动语句缓存。从驱动程序日志中,我验证了在第一个查询之后执行后续查询使用相同的语句句柄。
在执行了 3 次 selectprepared statement 查询后,我检查了 CLIENT_RESULT_CACHE_STATS$ 视图。但是这个视图没有产生任何行。
作为故障排除的一部分,我什至尝试将 /*+ RESULT_CACHE */ 提示添加到查询中,但视图没有给出任何结果。
从分析器(flextracer)中,我可以看到仍然对服务器进行 OCI 调用以获取选择查询的结果集。同样在启用 sql trace 时,我可以从 tkprof 看到每次执行查询都会增加在服务器上获取的行数,这表明 OCI 中的客户端结果集缓存不起作用。
有没有我错过的步骤?
提前致谢。