| 网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 |
![]() |
| Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道 |
在数据库日渐庞大时应该如何进行归档? 网管联盟bitsCN_com
以下是一些解决的思路:
网管下载dl.bitscn.com
◆1.新建一个表空间存放各表的历史数据。
1.1写一个存储过程搬数据,数据搬迁到历史表后,在基表中将搬迁的数据删除。
网管有家www.bitscn.net
◆2.定期将历史数据exp到磁带中去做永久保存。 网管u家u.bitscn@com
◆3.历史数据exp之后,可以清空各历史数据表。这样,表空间的大小实际上是很容易伸缩及控制的。
在这个过程当中,我们可以看到基本的数据由于可以定期清理到历史数据表,继而再清理到磁带。因此,数据库不会越来越大。方便备份及减少查询时间。 网管u家www.bitscn.net
具体的实现过程如下: 网管朋友网www_bitscn_net
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 网管网www_bitscn_com 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; 网管朋友网www_bitscn_net IF MOD(INTLOOP,200)=0 /*以200行为界记录归档情况*/ THEN INSERT INTO ARCHIVE_LOG VALUES('EMP_B',INTLOOP,SYSDATE); COMMIT; END IF; END LOOP; END ARCHIVE_EMP; 网管有家bitscn.net |
|
0
|
评论加载中…