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以后的就可以不用考虑了;

转载于:https://my.oschina.net/nly/blog/346390

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值