网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle常見問題集(二).
.ORA-02020错误:过多的数据库连接.
.Oracle远程复制和异地容灾方案分.
.Oracle安全全接触(完整版)一.
.Oracle Portal及其门户网站.
.oracle中设置自增主键.
.实例讲解Oracle的快速删除和快速.
.系统的物理上不连续的碎片数计算.
.如何查看什么时间有哪些数据库对.
.深入讲解如何使用rollup配合grou.
.在PL/SQL 开发中调试存储过程和函.
.执行程式: 多工与 Session.
.Oracle与Access表之间的导入和导.
.Oracle数据库中快照的使用.
.怎样修改查看Oracle字符集及怎样.
.介绍几个基本的 SQLPLUS 命令.
.Oracle Forms Server Troublesho.
.在ORACLE中利用角色增强应用系统.
.利用Oracle自带的连接池类的一例.
.关于 SELECT N 问题.

Oracle数据库中快照的使用

发表日期:2008-2-9



   Oracle数据库的快照是一个表,它包含有对一个本地或远程数据库上一个或多个表或视图的查询的结果。正因为快照是一个主表的查询子集,使用快照可以加快数据的查询速度;在保持不同数据库中的两个表的同步中,利用快照刷新,数据的更新性能也会有很大的改善。
  
  ---- 下面以我在开发襄樊市电信局170话费催缴系统中使用快照加快查询速度的实现过程为例来说明快照的使用方法:
  
  ---- 170话费催缴系统是一个向用户电话播放催缴话费提示音的系统。用户的欠费金额存放在rs6000小型机sffw用户下的表yh_qfcx中(yh_qfcx表是一个随用户缴费情况动态变化的欠费记录表),而催缴系统的数据按要求存放在另外一台xf170服务器dmtcx用户下,为在dmtcx用户下使用sffw用户下表yh_qfcx中的部分数据,我在dmtcx用户下建立了yh_qfcx的快照S_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
     Start with sysdate+1/2880 next sysdate+1;
  {此SQL语句的意思为:设定oracle自动在30钞
  (30/24*60*60)后进行第一次完全刷新,
  以后每隔1天完全刷新一次。}
  ---- 说明:
  
  ---- 1、因为快照刷新是服务器自动完成的,所以要保证oracle数据库启动了快照刷新进程。查看oracle数据库是否启动了快照刷新进程,可以以数据库sys身份查看视图V_$SYSTEM_PARAMETER中的参数snapshot_refresh_processes的值是否为1,假如不为1,则快照刷新进程未启动。
  
  ---- 2、启动快照刷新进程的方法为:修改oracle数据库的初始化文件initorcl.ora,将其中的snapshot_refresh_processes参数的值改由0改为1,然后重新启动oracle数据即可。
  
  ---- 3、需要说明的是:建立快照日志时oracle数据库为我们建立了一个基于yh_qfcx的触发器tlog$_yh_qfcx和快照日志表mlog$_yh_qfcx;建立快照时oracle数据库为我们建立了一个表、两个视图、一个索引,它们分别为:
  
  一个表:snap$_s_yh_qfcx;
  两个视图:mview$_s_yh_qfcx和s_yh_qfcx; 一个索引:I_snap$_s_yh_qfcx(
   基于表snap$_s_yh_qfcx中的m_row$$字段。
上一篇:怎样识别IO竞争和负载平衡? 人气:595
下一篇:怎样查看init.ora文件? 人气:1206
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐