网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Oracle > 性能调优 > 在数据库日渐庞大时进行归档-性能调优  

在数据库日渐庞大时进行归档-性能调优

2008-07-23  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

        在数据库日渐庞大时应该如何进行归档? 网管联盟bitsCN_com

        以下是一些解决的思路:

网管下载dl.bitscn.com

        ◆1.新建一个表空间存放各表的历史数据。

网管有家bitscn.net

        1.1写一个存储过程搬数据,数据搬迁到历史表后,在基表中将搬迁的数据删除。

网管有家www.bitscn.net

        ◆2.定期将历史数据exp到磁带中去做永久保存。 网管u家u.bitscn@com

        ◆3.历史数据exp之后,可以清空各历史数据表。这样,表空间的大小实际上是很容易伸缩及控制的。

网管有家www.bitscn.net

        在这个过程当中,我们可以看到基本的数据由于可以定期清理到历史数据表,继而再清理到磁带。因此,数据库不会越来越大。方便备份及减少查询时间。 网管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
网管网www_bitscn_com

        2.创建归档表:

         sql>create table emp_archive as select * from emp_b;
网管u家www.bitscn.net

        3.创建归档记录表:

         CREATE TABLE SCOTT.ARCHIVE_LOG
        (
        TABLENAME VARCHAR2(50 BYTE),
        RECORDCOUNT NUMBER,
        UPDATEDATE DATE
        )
        LOGGING
        NOCOMPRESS
        NOCACHE
        NOPARALLEL
        MONITORING
网管u家u.bitsCN.com

        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;

网管网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

网管u家www.bitscn.net

TAGs性能   进行   庞大         COMMIT   历史数据   数据   FROM    
 上一篇:Oracle数据库启动监听器不启动或打开出错-性能调优   下一篇:Oracle数据库维护常用SQL语句集合-性能调优
在数据库日渐庞大时进行归档-性能调优 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: