Result Cache , Shared Global Area (SGA) içindeki shared pool alanındaki , bellek alanıdır. Bu alanda tekrar kullanım için veritabanı sorgu sonucu veya sorgu bloğu tutulur. Cache’lenmiş bloklar , sql cümleleri ve stale durumda olmayan oturumlar tarafından paylaşılır.
Result Cache kullanımı küçük ve sık erişim gerektiren tablolar için idealdir. Büyük tablolar için kullanılması sıkıntı yaratabilir. Fakat sürekli sorgulanan kullanıcı bilgileri, parametre gibi tablolarda çok ciddi kazanım sağlayacaktır.
Result Cache , Oracle Database 11g Release 1 versiyonuyla gelmiş olup , varsayılan olarak enable durumdadır.
Result Cache durumunu aşağıdaki sorgu ile öğrenebiliriz .
SQL> SELECT dbms_result_cache.status() FROM dual; DBMS_RESULT_CACHE.STATUS() -------------------------------------------------------------------------------- ENABLED
Result cache ile ilgili iki önemli parametrenin set edilmesinde fayda var. result_cache_max_size ve shared_pool_size için aşağıdaki gibi bir değer atamanız , sistemi dar boğaza sokmamak için gereklidir. Belleğinize göre yada ihtiyacınıza göre bu parametreleri ayarlayabilirsiniz.
SQL> ALTER SYSTEM SET result_cache_max_size = 2G SCOPE = SPFILE; SQL> ALTER SYSTEM SET shared_pool_size = 2G SCOPE = SPFILE;
Sonrasında veritabanını yeniden başlatmak gerekecektir.
Result Cahce kullanımı için sorguya /*+ RESULT_CACHE */ hinti eklemek gerekmektedir. Örnek sorgu aşağıdaki gibidir.
SQL> SELECT /*+ RESULT_CACHE */ p.prod_name, SUM (s.amount_sold) AS total_revenue, SUM (s.quantity_sold) AS total_sales FROM sales s, products p WHERE s.prod_id = p.prod_id GROUP BY p.prod_name;
Result cahce kullanımı varsayılan olarak manuel yönetilmektektedir. Dilersek bunu zorlayarak otomatik kullanılmasını da sağlayabiliriz. result_cache_mode parametresinin değerine göre bu kullanım mümkündür. Varsayılan olarak MANUAL şeklinde olup dilersek FORCE yaparak result cache kullanımına zorlayabiliriz sistemi. Kullanım durumu result_cache_max_size parametresi ile sınırlandırılmaktadır.
result_cache_mode parametresini aşağıdaki gibi değiştirebiliriz.
SQL> alter system set result_cache_mode=FORCE scope=both sid='*'; System altered.
result_cache_mode parametresi FORCE yapıldığında bile eğer sorguda NO_RESULT_CACHE hinti belirtildiyse , result cache kullanılmayacaktır. Hint , daima parametreden daha üstündür.
Aşağıdaki sorgu ile result cache kullanılan nesneleri tespit edebilirsiniz.
SQL> SELECT name, TYPE, cache_id, row_count FROM v$result_cache_objects ORDER BY creation_timestamp;
Result cache bilgilerinin bazı durumlarında temizlenmesi gerekebilir. Mevcut cache bilgilerini aşağıdaki şekilde temizleyebilirsiniz.
SQL> BEGIN DBMS_RESULT_CACHE.FLUSH; END; / PL/SQL procedure successfully completed.
Result Cache kullanıldığında bellek tarafındaki durumun da izlenmesi gerekir. Bu izlemeyi Result Cache Memory Report ile sağlamak mümkündür. Bu raporu aşağıdaki şekilde oluşturabilirsiniz. Bu rapor sayesinde anlık olarak bellek kullanımını ve ayarlamalarını görebiliriz.
SQL> set serveroutput on SQL> exec dbms_result_cache.memory_report(TRUE); 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 = 52448K bytes (52448 blocks) Maximum Result Size = 2622K bytes (2622 blocks) [Memory] Total Memory = 174336 bytes [0.004% of the Shared Pool] ... Fixed Memory = 14880 bytes [0.000% of the Shared Pool] ....... Memory Mgr = 200 bytes ....... Cache Mgr = 208 bytes ....... Bloom Fltr = 2K bytes ....... = 4120 bytes ....... RAC Cbk = 5408 bytes ....... State Objs = 2896 bytes ... Dynamic Memory = 159456 bytes [0.004% of the Shared Pool] ....... Overhead = 126688 bytes ........... Hash Table = 64K bytes (4K buckets) ........... Chunk Ptrs = 24K bytes (3K slots) ........... Chunk Maps = 12K bytes ........... Miscellaneous = 126688 bytes ....... Cache Memory = 32K bytes (32 blocks) ........... Unused Memory = 31 blocks ........... Used Memory = 1 blocks ............... Dependencies = 0 blocks (0 count) ............... Results = 1 blocks ................... SQL = 1 blocks (1 count) PL/SQL procedure successfully completed.
Result Cache ile ilgili bilgi alabileceğiniz diğer bir view ise v$result_cache_statistics şeklindedir. Bu görüntüden de mevcut durum ile ilgili bilgi toplanabilir.
SQL> select name, value from v$result_cache_statistics; NAME VALUE ------------------------------ -------------------- Block Size (Bytes) 1024 Block Count Maximum 3072000 <<<<<<<<<<< 3 GB Result Cache maximum size Block Count Current 1038720 <<<<<<<<<<< 1 GB is currently used Result Size Maximum (Blocks) 153600 Create Count Success 1047967 Create Count Failure 80 Find Count 1312482070 Invalidation Count 9056 Delete Count Invalid 9402 Delete Count Valid 0 Hash Chain Length 237-269 Find Copy Count 1312537867 Latch (Share) 0