logo 广告
Loading...
 导航 所在位置:论坛首页 -> ┈┋电脑网络┋┈ -> 数据库技术 -> 讲解Oracle数据库逐渐增大时的归档处理
回复
标题:讲解Oracle数据库逐渐增大时的归档处理收藏 编辑 删除 楼主 | 上一篇 下一篇
有时也很傻
头像
等级:职业侠客
权限:普通用户
积分:70
金钱:6359
声望:106
经验:106
发帖数:1556
注册:2007年10月26日
资料 短消息2008-6-13 11:06:53
问:在数据库日渐庞大时应该如何进行归档?

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

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;

/

签名

2008-6-13 11:06:53 顶部
第1页 共页 共0个回复     <<    >>    
 快速回复
  • 支持UBB,HTML标签

  • 高级回复

  • 操作选项:评分 加精 解精 奖惩 设专题 设公告 解公告 固顶 总固顶 解固顶 结帖 解结帖 锁帖 解锁 移帖 删帖
      首页 | 购买指南 | 虚拟主机 | 特色介绍 | 下载中心 | 支付方式
    Copyright 2004-2008 BBSGood.com Powered By: BBSGood.Speed Version 5.0
      咨询电话:0575-85513832、0575-85513825(传真)、7*24小时咨询服务:13606552007 不良信息举报中心 浙ICP备05029817号
      业务QQ:38958768、客服QQ1:415896239、客服QQ2:343896043、MSN:jccsxx@hotmail.com