ORACLE函数缓存

我们在系统中,很多时候,会对一个相对固定的表反复查询,频率特别高;

比如-->:
人员信息表,相对很固定,系统稳定后,很少增删改, 根据输入的人员编号获取
人员名称,如果每次查询之后,把结果缓存在会话里,该多好;
省的每次SELECT 一下,挺浪费的; 
所以最好让数据库“智能”识别;如果这个查询执行过了,就记录到会话的缓存;
如果这个表发生变化了,这个缓存自动清除;
办法是这样的:
写一个简单的函数-->
create function get_user_name(p_user_no varchar2) return varchar2  RESULT_CACHE  /*就靠 RESULT_CACHE 来智能识别*/
    IS
    V_user_name varchar2(40);
    BEGIN
    DMBS_OUTPUT.PUT_LINE('获取'||p_user_no ||'的名称');
     SELECT USER_NAME INTO V_USER_NAME FROM USER_INFO WHERE USER_NO=P_USER_NO;
      RETURN V_USER_NMAE;
    EXCEPTION 
       WHEN OTHERS THEN 
          RETURN NULL;
   END;
   然后你就执行该函数
   SELECT get_user_name('0001') FROM DUAL;
   第一次执行,你会发现有DMBS_OUTPUT的输出:获取0001的名称
   第二次执行,你会惊讶的发现没有DMBS_OUTPUT的输出了,这就说明该函数的结果被缓存
   在会话内存了;
   当然第三次...,后面都不会有DMBS_OUTPUT输出了;
   是不是很爽,不光人员信息,一些数据字典表的信息获取,参数表的信息获取,凡是表
   相对比较静态的,都可以这样做;
   不过,只要你把人员表USER_INFO 的任何数据修改一下,或删除或增加,内存都会被自动
   清除,这样目的是防止缓存的数据是脏数据,
   数据库这样处理也是对的,表一点有任何变化,相应的函数缓存全部清除;
   如果11g之前的版本,需要这样定义
   create function get_user_name(p_user_no varchar2) return varchar2  
   RESULT_CACHE relies_on (USER_INFO)
   否则数据库不知道是根据user_info 表发生变化了清除缓存,这样就可能导致脏读;
   11g以后的就可以不用考虑了;

你可能感兴趣的:(ORACLE函数缓存)