讲解Oracle数据库逐渐增大时的归档处理Oracle认证考试

文章作者 100test 发表时间 2009:05:15 17:47:19
来源 100Test.Com百考试题网


  问:在数据库日渐庞大时应该如何进行归档?
  答:以下是一些解决的思路:
  1.新建一个表空间存放各表的历史数据。
  1.1写一个存储过程搬数据,数据搬迁到历史表后,在基表中将搬迁的数据删除。
  2.定期将历史数据exp到磁带中去做永久保存。
  3.历史数据exp之后,可以清空各历史数据表。这样,表空间的大小实际上是很容易伸缩及控制的。
  在这个过程当中,我们可以看到基本的数据由于可以定期清理到历史数据表,继而再清理到磁带。因此,数据库不会越来越大。方便备份及减少查询时间。
  具体的实现过程如下:
  1.创建临时表:
  CREATE GLOBAL TEMPORARY TABLE SCOTT.ARCHIVE_ROWS
  (
  CROWID VARCHAR2(20 BYTE),
  PRIMARYKEY VARCHAR2(15 BYTE)
  )
  ON COMMIT PRESERVE ROWS
  /
  2.创建归档表:
  sql>.create table emp_archive as 0select * from emp_b.
  3.创建归档记录表:
  CREATE TABLE SCOTT.ARCHIVE_LOG
  (
  TABLENAME VARCHAR2(50 BYTE),
  RECORDCOUNT NUMBER,
  UPDATEDATE DATE
  )
  LOGGING
  NOCOMPRESS
  NOCACHE
  NOPARALLEL
  MONITORING
  /
  4. procedure:
  CREATE OR REPLACE PROCEDURE archive_emp
  (maxarchiverow number) IS /* 定义归档的记录数*/
  v_crowid archive_rows.crowid%type. /* 存放基表的rowid*/
  intLoop number. /* 记数器*/
  v_primarykey archive_rows.PRIMARYKEY%type.
  CURSOR C_ARCH_EMP IS
  SELECT * FROM ARCHIVE_ROWS. /* 创建游标*/
  BEGIN
  DELETE FROM ARCHIVE_ROWS. /*先清空临时表*/
  COMMIT.
  INSERT INTO ARCHIVE_ROWS
  SELECT ROWID, FROM EMP_B WHERE ROWNUM <. MAXARCHIVEROW.
  COMMIT. /*将基表中指定行数的rowid插入临时表*/
  INTLOOP:=0.
  OPEN C_ARCH_EMP.
  LOOP FETCH C_ARCH_EMP INTO V_CROWID,V_PRIMARYKEY.
  INTLOOP:=INTLOOP 1.
  EXIT WHEN C_ARCH_EMP%NOTFOUND.
  INSERT INTO EMP_ARCHIVE SELECT * FROM EMP_B WHERE ROWID=V_CROWID.
  /*根据rowid,将数值插入到归档表中*/
  COMMIT.
  DELETE FROM EMP_B WHERE ROWID=V_CROWID. /*将基表已归档数据删除*/
  COMMIT.
  IF MOD(INTLOOP,200)=0 /*以200行为界记录归档情况*/
  THEN
  INSERT INTO ARCHIVE_LOG VALUES(EMP_B,INTLOOP,SYSDATE).
  COMMIT.
  END IF.
  END LOOP.
  END ARCHIVE_EMP.
  /
  更多优质资料尽在百考试题论坛 百考试题在线题库 oracle/认证更多详细资料

相关文章


Oracle下导入txt的shell脚本以及配置Oracle认证考试
oracle认证:关于Oracle的序列(Sequence)使用Oracle认证考试
讲解Oracle数据库逐渐增大时的归档处理Oracle认证考试
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛