Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103068430
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-03-31 07:59:19

来源:赛迪网    作者:Dennis

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

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

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;
/
阅读(300) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~