返回顶部
首页 > 资讯 > 精选 >如何理解DBMS_RESULT_CACHE管理结果缓存的包
  • 501
分享到

如何理解DBMS_RESULT_CACHE管理结果缓存的包

2023-06-06 02:06:16 501人浏览 薄情痞子
摘要

本篇文章给大家分享的是有关如何理解DBMS_RESULT_CACHE管理结果缓存的包,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。oracle 11g提供了DBMS_RESUL

本篇文章给大家分享的是有关如何理解DBMS_RESULT_CACHE管理结果缓存的包,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

oracle 11g提供了DBMS_RESULT_CACHE包来查询sql结果缓存内容的状态和适当地控制SQL结果缓存内容。

DBMS_RESULT_CACHE功能和存储过程
功能/存储过程    描述
STATUS:  返回结果缓存的当前状态。值包括:
     ENABLED: 结果缓存是激活的。
     DISABLED:结果缓存是不可用的。
     BYPASSED:结果缓存暂时不可用。
     SYNC:    结果缓存是可用的,但是目前正与其他RAC节点重新同步。
MEMORY_REPORT: 列出结果缓存内存利用的一个概要(默认)或详细的报表。
FLUSH:  推出整个结果缓存的内容。
INVALIDATE:  使结果缓存中一个特定对象的缓存结果无效。
INVALIDATE_OBJECT: 根据缓存ID使一特定结果缓存无效。
下面通过具体的实验给予介绍:
一 STATUS:  返回结果缓存的当前状态。
yang@rac1>select dbms_result_cache.status() from dual;
DBMS_RESULT_CACHE.STATUS()
--------------------------------------------------------
ENABLED
二 MEMORY_REPORT: 列出结果缓存内存利用的一个概要(默认)或详细的报表。视图v$result_cache_statistics 是MEMORY_REPORT相同的描述
yang@rac1>exec dbms_result_cache.memory_report();
R e s u l t   C a c h e   M e m o r y   R e p o r t
[Parameters]
Block Size          = 1K bytes
Maximum Cache Size  = 15744K bytes (15744 blocks)
Maximum Result Size = 787K bytes (787 blocks)
[Memory]
Total Memory = 12704 bytes [0.001% of the Shared Pool]
... Fixed Memory = 12704 bytes [0.001% of the Shared Pool]
... Dynamic Memory = 0 bytes [0.000% of the Shared Pool]
PL/SQL procedure successfully completed.
yang@rac1>select * from v$result_cache_statistics;

        ID NAME                           VALUE
---------- ------------------------------ ---------------------------------------------------------------------------------
         1 Block Size (Bytes)             1024
         2 Block Count Maximum            15744
         3 Block Count Current            0
         4 Result Size Maximum (Blocks)   787
         5 Create Count Success           0
         6 Create Count Failure           0
         7 Find Count                     0
         8 Invalidation Count             0
         9 Delete Count Invalid           0
        10 Delete Count Valid             0
        11 Hash Chain Length              0
        12 Global Hit Count               0
        13 Global Miss Count              0
13 rows selected.
yang@rac1>set autotrace on
yang@rac1>select count(*) from yanGobj;
  COUNT(*)
----------
     74484
Execution Plan
----------------------------------------------------------
Plan hash value: 362321706
------------------------------------------------------------------------------------------
| Id  | Operation           | Name                       | Rows  | Cost (%CPU)| Time     |
------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT    |                            |     1 |   297   (1)| 00:00:04 |
|   1 |  RESULT CACHE       | 7uz1ww4x7gs2a6ba4qjauzt4bq |       |            |          |
|   2 |   SORT AGGREGATE    |                            |     1 |            |          |
|   3 |    TABLE ACCESS FULL| YANGOBJ                    | 61204 |   297   (1)| 00:00:04 |
------------------------------------------------------------------------------------------
Result Cache InfORMation (identified by operation id):
------------------------------------------------------
   1 - column-count=1; dependencies=(YANG.YANGOBJ); attributes=(single-row); name="select count(*) from yangobj"
Note
-----
   - dynamic sampling used for this statement (level=2)
Statistics
----------------------------------------------------------
          9  recursive calls
          4  db block gets
       1126  consistent gets
          0  physical reads
        548  redo size
        528  bytes sent via SQL*Net to client
        520  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed

yang@rac1>/
  COUNT(*)
----------
     74484
Execution Plan
----------------------------------------------------------
Plan hash value: 362321706
------------------------------------------------------------------------------------------
| Id  | Operation           | Name                       | Rows  | Cost (%CPU)| Time     |
------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT    |                            |     1 |   297   (1)| 00:00:04 |
|   1 |  RESULT CACHE       | 7uz1ww4x7gs2a6ba4qjauzt4bq |       |            |          |
|   2 |   SORT AGGREGATE    |                            |     1 |            |          |
|   3 |    TABLE ACCESS FULL| YANGOBJ                    | 61204 |   297   (1)| 00:00:04 |
------------------------------------------------------------------------------------------
Result Cache Information (identified by operation id):
------------------------------------------------------
   1 - column-count=1; dependencies=(YANG.YANGOBJ); attributes=(single-row); name="select count(*) from yangobj"
Note
-----
   - dynamic sampling used for this statement (level=2)
Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
          0  consistent gets
          0  physical reads
          0  redo size
        528  bytes sent via SQL*Net to client
        520  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed
从视图v$result_cache_objects中获取CACHE_ID。
yang@rac1>select name,status,cache_id from v$result_cache_objects;
NAME                           STATUS    CACHE_ID
------------------------------ --------- -----------------------------------
YANG.YANGOBJ                   Published YANG.YANGOBJ
select cou Published 7uz1ww4x7gs2a6ba4qjauzt4bq
nt(*) from yangobj

三 INVALIDATE_OBJECT: 根据缓存ID--CACHE_ID使一特定结果缓存无效。
yang@rac1>exec DBMS_RESULT_CACHE.INVALIDATE_OBJECT('7uz1ww4x7gs2a6ba4qjauzt4bq');
PL/SQL procedure successfully completed.
yang@rac1>select name,status,cache_id from v$result_cache_objects;
NAME                           STATUS    CACHE_ID
------------------------------ --------- -----------------------------------
YANG.YANGOBJ                   Published YANG.YANGOBJ
select cou Invalid   7uz1ww4x7gs2a6ba4qjauzt4bq
nt(*) from yangobj
四 FLUSH:  清理整个结果缓存的内容。
yang@rac1>exec dbms_result_cache.memory_report();
R e s u l t   C a c h e   M e m o r y   R e p o r t
[Parameters]
Block Size          = 1K bytes
Maximum Cache Size  = 2080K bytes (2080 blocks)
Maximum Result Size = 104K bytes (104 blocks)
[Memory]
Total Memory = 107812 bytes [0.049% of the Shared Pool]
... Fixed Memory = 9460 bytes [0.004% of the Shared Pool]
... Dynamic Memory = 98352 bytes [0.045% of the Shared Pool]
....... verhead = 65584 bytes
....... Cache Memory = 32K bytes (32 blocks)
........... Unused Memory = 26 blocks
........... Used Memory = 6 blocks
............... Dependencies = 3 blocks (3 count)
............... Results = 3 blocks
................... SQL     = 2 blocks (2 count)
................... Invalid = 1 blocks (1 count)

PL/SQL 过程已成功完成。

已用时间:  00: 00: 00.35
yang@rac1>exec dbms_result_cache.flush();

PL/SQL 过程已成功完成。

已用时间:  00: 00: 00.02
yang@rac1>exec dbms_result_cache.memory_report();
R e s u l t   C a c h e   M e m o r y   R e p o r t
[Parameters]
Block Size          = 1K bytes
Maximum Cache Size  = 2080K bytes (2080 blocks)
Maximum Result Size = 104K bytes (104 blocks)
[Memory]
Total Memory = 9460 bytes [0.004% of the Shared Pool]
... Fixed Memory = 9460 bytes [0.004% of the Shared Pool]
... Dynamic Memory = 0 bytes [0.000% of the Shared Pool]

PL/SQL 过程已成功完成。

已用时间:  00: 00: 00.02
结果缓存已被清除。

以上就是如何理解DBMS_RESULT_CACHE管理结果缓存的包,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注编程网精选频道。

--结束END--

本文标题: 如何理解DBMS_RESULT_CACHE管理结果缓存的包

本文链接: https://lsjlt.com/news/245842.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何理解DBMS_RESULT_CACHE管理结果缓存的包
    本篇文章给大家分享的是有关如何理解DBMS_RESULT_CACHE管理结果缓存的包,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Oracle 11g提供了DBMS_RESUL...
    99+
    2023-06-06
  • 如何理解缓存
    这篇文章主要介绍“如何理解缓存”,在日常操作中,相信很多人在如何理解缓存问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何理解缓存”的疑惑有所帮助!接下来,请跟着小编一起来学...
    99+
    2024-04-02
  • PHP 缓存打包技术:如何实现高效存储和管理?
    随着互联网技术的不断发展,PHP 作为一种广泛应用于 Web 开发的编程语言,其性能优化问题也越来越受到开发者的关注。其中,缓存技术是提高 PHP 应用性能的常见手段之一。而缓存打包技术,则更进一步实现了高效存储和管理。 一、缓存的基本概...
    99+
    2023-06-19
    缓存 打包 存储
  • NHibernate缓存管理机制怎么理解
    这篇文章主要介绍“NHibernate缓存管理机制怎么理解”,在日常操作中,相信很多人在NHibernate缓存管理机制怎么理解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”NHibernate缓存管理机制怎...
    99+
    2023-06-17
  • 如何理解Hiberate3 Session缓存
    这篇文章给大家介绍如何理解Hiberate3 Session缓存,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Hiberate3有很多值得学习的地方,这里我们主要介绍Hiberate3 Session缓存,包括介绍Li...
    99+
    2023-06-17
  • 如何处理PHP开发中的文件缓存和内存管理
    在PHP开发中,文件缓存和内存管理是两个非常重要的方面。良好的文件缓存和内存管理可以显著提升应用的性能和可靠性。本文将介绍如何在PHP中进行文件缓存和内存管理,并给出具体的代码示例。一、文件缓存文件缓存是将已经生成的内容保存在文件中,下次访...
    99+
    2023-10-21
    内存管理 PHP开发 文件缓存
  • C++内存管理如何理解
    这期内容当中小编将会给大家带来有关C++内存管理如何理解,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言;C++继承了C语言的指针,一直以来指针的一些问题困扰着开发人员,常见的指针问题主要有:内存泄露、...
    99+
    2023-06-26
  • 如何使用 PHP 缓存打包技术进行高效存储和管理?
    PHP 是一种常用的服务器端脚本语言,它被广泛应用于 web 开发中。在 web 应用中,缓存是一种非常重要的技术,它可以显著提高应用程序的性能。本文将介绍如何使用 PHP 缓存打包技术进行高效存储和管理。 缓存是一种将数据存储在内存中的技...
    99+
    2023-06-19
    缓存 打包 存储
  • webpack如何独立打包和缓存处理
    这篇文章将为大家详细讲解有关webpack如何独立打包和缓存处理,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。webpack最基本的配置文件来打包压缩我们的代码:var&...
    99+
    2024-04-02
  • PHP开发中如何处理文件缓存和内存管理
    在PHP开发中,文件缓存和内存管理是非常重要的方面。合理处理文件缓存可以提高系统的性能和响应速度,而良好的内存管理可以有效地减少内存泄漏和提升系统的稳定性。本文将详细介绍如何在PHP开发中处理文件缓存和内存管理,并提供具体的代码示例。文件缓...
    99+
    2023-10-21
    内存管理 PHP开发 文件缓存
  • 如何在Java中实现高效的缓存加载和缓存管理?
    Java作为一门广泛应用于企业级应用的编程语言,在实现高效的缓存加载和缓存管理方面也有着非常出色的表现。本文将详细介绍如何在Java中实现高效的缓存加载和缓存管理。 一、什么是缓存? 缓存是指将计算出来的结果或者是需要频繁读取的数据存储在内...
    99+
    2023-09-27
    load 缓存 编程算法
  • 详解Spring整合Ehcache管理缓存
    前言Ehcache 是一个成熟的缓存框架,你可以直接使用它来管理你的缓存。Spring 提供了对缓存功能的抽象:即允许绑定不同的缓存解决方案(如Ehcache),但本身不直接提供缓存功能的实现。它支持注解方式使用缓存,非常方便。 ...
    99+
    2023-05-31
    ehcache spring hcache
  • linux如何清理rpm缓存删除下载的包
    ...
    99+
    2024-04-02
  • NPM包管理器:Java缓存和日志的完美解决方案?
    NPM(Node Package Manager)是一个流行的包管理器,被广泛用于Node.js开发中。但是,它也可以用于Java应用程序,特别是在缓存和日志方面。在本文中,我们将探讨如何使用NPM来管理Java缓存和日志,以及为什么它是...
    99+
    2023-08-14
    缓存 日志 npm
  • golang函数缓存的内存管理策略解读
    内存管理策略:go 语言函数缓存提供三种内存管理策略:全局内存管理:所有函数共享一个全局缓存表。局部内存管理:每个包或模块有自己的缓存表,仅缓存内部定义的函数。混合内存管理:结合全局和局...
    99+
    2024-05-02
    golang 函数缓存
  • 如何理解Linux进程的内存管理
    这篇文章给大家介绍如何理解Linux进程的内存管理,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。几个关键的数据结构一个进程的虚拟地址空间主要由两个数据结来描述,一个是 mm_struct,一个是 vm_area_str...
    99+
    2023-06-15
  • 如何理解Java代码的内存管理
    这期内容当中小编将会给大家带来有关如何理解Java代码的内存管理,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。小编通过几个方面来介绍Java代码的内存管理。有的代码,GC根本就回收不了,直接系统挂掉。GC...
    99+
    2023-06-17
  • ASP 缓存对象:解开内存管理难题
    ASP.NET 的缓存对象允许您存储和检索经常访问的数据,从而优化应用程序性能。这可以通过避免昂贵的数据库查询或计算密集型操作来实现。本文将深入探讨 ASP 缓存对象,展示如何使用它来解决内存管理问题并提高您的应用程序效率。 缓存的类型 ...
    99+
    2024-03-01
    ASP.NET 缓存 内存管理 对象 实例化 性能优化
  • linux如何从下载的软件包中清理缓存
    ...
    99+
    2024-04-02
  • Python在Linux上如何管理缓存和日志?
    随着Web应用程序的不断发展,缓存和日志管理成为了越来越重要的任务。Python是一种强大的编程语言,可以用于在Linux系统上管理缓存和日志。在本文中,我们将介绍如何使用Python在Linux上管理缓存和日志。 一、缓存管理 缓存的...
    99+
    2023-10-10
    linux 缓存 日志
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作