国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

在數據庫日漸龐大時進行歸檔的解決思路

2024-07-21 02:44:11
字體:
來源:轉載
供稿:網友


問:在數據庫日漸龐大時應該如何進行歸檔?


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

 

◆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;

/


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 镇原县| 湖州市| 葵青区| 治多县| 大化| 宁远县| 南安市| 元阳县| 海口市| 东兴市| 孟州市| 平陆县| 东丰县| 石门县| 河北区| 孝义市| 普洱| 砀山县| 井冈山市| 资溪县| 舞钢市| 彭泽县| 通辽市| 南丹县| 苍南县| 阿克苏市| 凤阳县| 彰化县| 临湘市| 丹江口市| 呼玛县| 通河县| 乡城县| 荃湾区| 甘谷县| 湖北省| 西城区| 建阳市| 本溪市| 江达县| 太仓市|