我们在系统中,很多时候,会对一个相对固定的表反复查询,频率特别高;
比如-->:
人员信息表,相对很固定,系统稳定后,很少增删改, 根据输入的人员编号获取
人员名称,如果每次查询之后,把结果缓存在会话里,该多好;
省的每次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以后的就可以不用考虑了;
1488

被折叠的 条评论
为什么被折叠?



