問:在數據庫日漸龐大時應該如何進行歸檔?
答:以下是一些解決的思路:
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;
/
詳細講解Oracle數據庫10g RMAN的備份過程1.首先查看一下Oracle的數據文件 SQL> select name from v$datafile; NAME ------------------------------------- /dev/rora_system /dev/rora_undo1 /dev/rora_sysaux /dev/rora_users /dev/rora_example 2.建立...查看完整版>>
詳細講解Oracle數據庫10g RMAN的備份過程
實例講解"Oracle"數據庫的分頁顯示Create PROCEDURE pageTest --用于翻頁的測試 --需要把排序字段放在第一列 ( @FirstID nvarchar(20)=null, --當前頁面裏的第一條記錄的排序字段的值 @LastID nvarchar(20)=null, --當前頁面裏的最後一條記錄的排序字...查看完整版>>
實例講解"Oracle"數據庫的分頁顯示
Oracle數據庫回滾段表空間文件丟失的處理如果你檢測到丟失或損壞了回滾段表空間的數據文件,並且數據庫是運行著的,不要把它 down 掉。在很多情況下,數據庫是啓著的比關閉著解決問題更容易些。 這種情況的兩種可能的解決方法: (A) 使丟失的那個數據文件 o...查看完整版>>
Oracle數據庫回滾段表空間文件丟失的處理
在客戶端處理Oracle的數據行加鎖問題數據的完整性和並發性: 在網絡數據庫處理數據中,需要保證數據的完整性、多事務的並發性和數據的一致性。數據庫系統必須最大限度的保證數據內容的有效性和合理性,使得數據合法與合理,即保證數據的完整性。...查看完整版>>
在客戶端處理Oracle的數據行加鎖問題
Oracle數據庫聯機日志文件丟失處理方法試驗一:用命令清空日志組方法 1、查看原來表中數據SQL>; conn test/test Connected. SQL>; select * from test; TEL---------- ...查看完整版>>
Oracle數據庫聯機日志文件丟失處理方法
在客戶端處理Oracle的數據行加鎖問題數據的完整性和並發性: 在網絡數據庫處理數據中,需要保證數據的完整性、多事務的並發性和數據的一致性。數據庫系統必須最大限度的保證數據內容的有效性和合理性,使得數據合法與合理,即保證數據的完整性。...查看完整版>>
在客戶端處理Oracle的數據行加鎖問題
Oracle數據庫中的EmptyString處理 跟 微軟的數據庫産品不一樣, Oralce 把 '' 空的string 自動替換爲 Null,所以下面的代碼你可能考慮不一樣的結果. create table suppliers ( supplier_id number, supplier_name varchar2(100)); N...查看完整版>>
Oracle數據庫中的EmptyString處理
Oracle數據庫聯機日志文件丟失處理方法 試驗一:用命令清空日志組方法 1、查看原來表中數據SQL>; conn test/test Connected. SQL>; select * from test; TEL ---------- 1 2 3 2、插入新數據SQL>; insert into test values(...查看完整版>>
Oracle數據庫聯機日志文件丟失處理方法
Oracle數據庫聯機日志文件丟失處理方法試驗一:用命令清空日志組方法 1、查看原來表中數據SQL>; conn test/test Connected. SQL>; select * from test; TEL---------- 1 2 3 2、插入新數據SQL>; insert into test values(4);1 row...查看完整版>>
Oracle數據庫聯機日志文件丟失處理方法