信息产业培训网

在数据库日渐庞大时进行归档的解决思路

http://www.miiceic.org.cn   2008-7-17 11:32:58   中程在线   浏览数:
关键字:数据库 庞大 归档 思路

 

  问:在数据库日渐庞大时应该如何进行归档?

 

  答:以下是一些解决的思路:

 

  ◆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 select * 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;

 

  /

来源:CCID
相关连接
最新评论
*以下网友发言不代表中程在线网站的观点和看法
    我要评论

    请您注意
    1、遵守中华人民共和国的各项有关法律规定
    2、承担一切因您的行为而导致的法律责任
    3、本网留言管理人员有权删除其管辖留言内容
    4、您在本网的留言本网有权在网站内转载和引用
    5、参与本留言即表明您已经阅读并接受上述条款
    我爱研发网中电华信阿里西西JAVA爱好者北京英才网全球大学查询网
    中国人的网站导航中国电脑论坛信息产业部新浪科技搜狐IT信息产业部电子教育与考试中心
    IT世界网软件项目交易网中国软件交易网国信培训网亚远景科技....[更多]
    关于我们 | 网站地图 | 周边住宿 | 行车路线 | 联系我们 | 网站律师 | 意见反馈 | 虚位以待 | 友情链接
    中程在线(北京)科技有限公司 版权所有
    总 部:北京市海淀区青东商务楼A座西四层
    企业培训部:010-52636110 52636106 就业培训部:010-68716925 68716926
    邮 件:training@miiceic.org.cn
    京ICP备06053134号
    Copyright © 2005-2008 Miiceic.org.cn All Rights Reserved