电脑软硬件应用网
当前位置: 电脑软硬件应用网 > 设计学院 > 网络编程 > 数据库 > 正文
在数据库日渐庞大时进行归档的解决思路
在数据库日渐庞大时进行归档的解决思路
2008-7-17 23:01:13  文/Alizze   出处:赛迪网   

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


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

 

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

/

  • 上一篇文章:

  • 下一篇文章:
  • 最新热点 最新推荐 相关文章
    Mysql数据库名和表名在不同系统下的…
    mysql全文搜索:sql的写法
    解答SQL不许在视图定义ORDER BY子句…
    数据库海量数据查询与优化
    SQL分组实例使用GROUP BY做示例
    图解Slide Window来做SqlServer性能…
    解决附加SQL Server数据库后出现只读…
    一次SQL调优数据库性能问题后的过程
    使用sql语句分离和附加数据库的方法
    一起探讨如何改善数据库性能瓶颈问题
    关于45IT | About 45IT | 联系方式 | 版权声明 | 网站导航 |

    Copyright © 2003-2011 45IT. All Rights Reserved 浙ICP备09049068号