oracle数据库的快照是一个表,它包含有对一个本地或远程数据库上一个或多个表或 视图的查询的结果。正因为快照是一个主表的查询子集,使用快照可以加快数据的查询速度; 在保持不同数据库中的两个表的同步中,利用快照刷新,数据的更新性能也会有很大的改善。 ---- 下面以我在开发襄樊市电信局170话费催缴系统中使用快照加快查询速度的实现过 ---- 170话费催缴系统是一个向用户电话播放催缴话费提示音的系统。用户的欠费金额存 放在rs6000小型机sffw用户下的表yh_qfcx中(yh_qfcx表是一个随用户缴费情况动态变化的欠 费记录表),而催缴系统的数据按要求存放在另外一台xf170服务器dmtcx用户下,为在dmtcx 用户下使用sffw用户下表yh_qfcx中的部分数据,我在dmtcx用户下建立了yh_qfcx的快照 ---- 具体步骤如下: 一、在sffw用户下建立表yh_qfcx的快照日志; ---- 只有先建立表yh_qfcx的快照日志,才能在快照中执行快速刷新。 ---- Create snapshot log on yh_qfcx; 二、在dmtcx用户下建立到sffw用户的数据库链link_sf; ---- 建立了到sffw用户的数据库链后才能从sffw用户下的表yh_qfcx中获取数据。 ---- Create database link link_sf ---- Connect to sffw identified by xxxxxxx using 'rs6000'; 三、在dmtcx用户下建立快照s_yh_qfcx; Create snapshot s_yh_qfcx as Select yhh,qf6+qf5+qf4+qf3+qf2+qf1+qf qfje
From yh_qfcx@link_sf Where tjbz='K' and bz6+bz5+bz4+bz3+bz2+bz1+bz>0; 四、根据需要修改快照刷新的间隔时间; ---- dmtcx用户下的快照s_yh_qfcx为了与sffw用户下的主表yh_qfcx保持同步,需要不 断刷新快照。只有设定了快照的刷新间隔时间,oracle才会自动刷新该快照。 ---- 快照的刷新有两种方式:快速刷新和完全刷新。快速刷新需要快照的主表先有快照 日志存在;完全刷新时oracle执行快照查询,将结果放入快照。快速刷新比完全刷新快,因为 快速刷新将主数据库的数据经网络发送到快照的数据少,仅需传送主表中修改过的数据,而完 Alter snapshot s_yh_qfcx refresh fast Start with sysdate+1/1440 next sysdate+1/144;
{此SQL语句的意思为:设定oracle自动在1分钟 (1/24*60)后进行第一次快速刷新,以后每隔10分钟 (10/24*60)快速刷新一次。} Alter snapshot s_yh_qfcx refresh complete