当前位置: 电脑软硬件应用网 > 设计学院 > 网络编程 > 数据库 > 正文 |
|
|||
在数据库日渐庞大时进行归档的解决思路 | |||
2008-7-17 23:01:13 文/Alizze 出处:赛迪网 | |||
问:在数据库日渐庞大时应该如何进行归档?
◆1.新建一个表空间存放各表的历史数据。
1.1写一个存储过程搬数据,数据搬迁到历史表后,在基表中将搬迁的数据删除。
◆2.定期将历史数据exp到磁带中去做永久保存。
◆3.历史数据exp之后,可以清空各历史数据表。这样,表空间的大小实际上是很容易伸缩及控制的。
在这个过程当中,我们可以看到基本的数据由于可以定期清理到历史数据表,继而再清理到磁带。因此,数据库不会越来越大。方便备份及减少查询时间。
具体的实现过程如下:
CREATE GLOBAL TEMPORARY TABLE SCOTT.ARCHIVE_ROWS ( CROWID VARCHAR2(20 BYTE), PRIMARYKEY VARCHAR2(15 BYTE) ) ON COMMIT PRESERVE ROWS /
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 /
CREATE OR REPLACE PROCEDURE archive_emp (maxarchiverow number) IS /* 定义归档的记录数*/ v_crowid archive_rows.crowid%type; /* 存放基表的rowid*/ intLoop number; /* 记数器*/ v_primarykey archive_rows.PRIMARYKEY%type;
SELECT * FROM ARCHIVE_ROWS; /* 创建游标*/
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;
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; / |
|||
关于45IT | About 45IT | 联系方式 | 版权声明 | 网站导航 | |
Copyright © 2003-2011 45IT. All Rights Reserved 浙ICP备09049068号 |