CTOCIO IT专家网

天极传媒 比特网 | 天极网 | IT专家网 | IT商网 | 52PK游戏网 | 手机天极 | IT分众 |
IT专家网搜索

数据库 | Oracle | DB2 | SQL Server | MySQL | 商业智能 | BI | DBA | Sybase| SQL Server 2008

您现在的位置: IT专家网 > 数据库子站 > 数据库技巧

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

作者: Alizze ,  出处:赛迪网, 责任编辑: 王晓晨, 
2008-07-17 10:22
  在数据库日渐庞大时进行归档的解决思路。

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

  答:解决的思路:

  ◆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;
  /

网友评论

笔名 
请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。    IT专家网友拥有管理笔名和留言的一切权利。
  • 周排行榜
  • 月排行榜

邮件订阅


    
天极服务 | 关于我们 | 网站律师 | 加入我们 | 联系我们 | 广告业务 | 友情链接 | 我要挑错
All Rights Reserved, Copyright 2004-2008, Ctocio.com.cn
渝ICP证B2-20030003号 如有意见请与我们联系 powered by 天极内容管理平台CMS4i