語法:
CREATE [PUBLIC] ROLLBACK SEGMENT rollback_segment
[TABLESPACE tablespace]
[STORAGE ([INITIAL integer[K|M]] [NEXT integer[K|M]]
[MINEXTENTS integer]
[MAXTENTS {integer|UNLIMITED}]
[OPTIMAL {integer[K|M]|NULL}]) ]
注:
回滾段可以在創建時指明PRIVATE或PUBLIC,一旦創建將不能修改。
MINEXTENTS 必須大於等於2
PCTINCREASE必須是0
OPTIMAL如果要指定,必須大於等於回滾段的初始大小(由MINEXTENTS指定)
建議:
一般情況下,INITIAL=NEXT
設置OPTIMAL參數來節約空間的使用
不要設置MAXEXTENTS爲UNLIMITED
回滾段應創建在一個特定的回滾段表空間內
例:
CREATE ROLLBACK SEGMENT rbs01
TABLESPACE rbs
STORAGE ( INITIAL 100K NEXT 100K MINEXTENTS 10
MAXEXTENTS 500 OPTIMAL 1000K);
使回滾段在線
當回滾段創建後,回滾段是離線的,不能被數據庫使用,爲了使回滾段被事務利用,必須將回滾段在線。可以用以下命令使回滾段在線:
ALTER ROLLBACK SEGMENT rollback_segment ONLINE;
例:
ALTER ROLLBACK SEGMENT rbs01 ONLINE;
爲了使回滾段在數據庫啓動時自動在線,可以在數據庫的參數文件中列出回滾段的名字。例如在參數文件中加入以下一行:
ROLLBACK_SEGMENT=(rbs01,rbs02)
修改回滾段的存儲參數
可以使用ALTER ROLLBACK SEGMENT命令修改回滾段的存儲參數(包括OPTIMAL,MAXEXTENTS)。
語法:
ALTER ROLLBACK SEGMENT rollback_segment
[STORAGE ([NEXT integer[K|M]]
[MINEXTENTS integer]
[MAXEXTENTS {integer|UNLIMITED}]
[OPTIMAL {integer[K|M]|NULL}]) ]
例:
ALTER ROLLBACK SEGMENT rbs01 STORAGE (MAXEXTENTS 1000);
回收回滾段的空間
如果指定了回滾段的OPTIMAL參數,ORACLE將自動回收回滾段到OPTIMAL指定的位置。用戶也可以手動回收回滾段的空間。
語法:
ALTER ROLLBACK SEGMENT rollback_segment SHRINK [TO integer [K|M]];
說明:
如果不指明TO integer的數值,ORACLE將試圖回收到OPTIMAL的位置。
例:
ALTER ROLLBACK SEGMENT rbs01 SHRINK TO
使回滾段離線
爲了達到以下兩個目的將要回滾段離線:
1.阻止新的事務使用該回滾段;
2.該回滾段必須刪除。
語法:
ALTER ROLLBACK SEGMENT rollback_segment OFFLINE;
例:
ALTER ROLLBACK SEGMENT rbs01 OFFLINE;
說明:
如果有事務正在使用該回滾段,運行該命令後,回滾段的狀態將是PENDING OFFLINE。事務結束後,狀態將改爲OFFLINE,可以通過V$ROLLSTAT查詢回滾段的狀態。
刪除回滾段
當回滾段不再需要或要重建以改變INITIAL,NEXT或MINEXTENTS參數時,可以將其刪除。要刪除回滾段,不許使該回滾段離線。
語法:
DROP ROLLBACK SEGMENT rollback_segment;
例:
DROP ROLLBACK SEGMENT rbs01;