讲解Oracle数据库逐渐增大时的归档处理
2008-06-16 03:03:54来源: 阅读 ()
答:以下是一些解决的思路:
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;
/
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 国外程序员整理的Java资源大全(全部是干货) 2020-06-12
- redis缓存 2020-06-12
- Spring系列.ApplicationContext接口 2020-06-11
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- 力扣题解 - 739. 每日温度 2020-06-11
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash