oracle 回滾段介紹(二)

創建回滾段
  語法:
  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}]) ]
  注:
   回滾段可以在創建時指明PRIVATEPUBLIC,一旦創建將不能修改。
   MINEXTENTS 必須大於等於2
   PCTINCREASE必須是0
   OPTIMAL如果要指定,必須大於等於回滾段的初始大小(由MINEXTENTS指定)
  建議:
   一般情況下,INITIAL=NEXT
   設置OPTIMAL參數來節約空間的使用
   不要設置MAXEXTENTSUNLIMITED
   回滾段應創建在一個特定的回滾段表空間內
  例:
  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命令修改回滾段的存儲參數(包括OPTIMALMAXEXTENTS)。
  語法:
  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 2M;
使回滾段離線
  爲了達到以下兩個目的將要回滾段離線:
  1.阻止新的事務使用該回滾段;
  2.該回滾段必須刪除。
  語法:
   ALTER ROLLBACK SEGMENT rollback_segment OFFLINE;
  例:
   ALTER ROLLBACK SEGMENT rbs01 OFFLINE;
  說明:
   如果有事務正在使用該回滾段,運行該命令後,回滾段的狀態將是PENDING OFFLINE。事務結束後,狀態將改爲OFFLINE,可以通過V$ROLLSTAT查詢回滾段的狀態。

刪除回滾段
  當回滾段不再需要或要重建以改變INITIALNEXTMINEXTENTS參數時,可以將其刪除。要刪除回滾段,不許使該回滾段離線。
語法:
  DROP ROLLBACK SEGMENT rollback_segment;
例:
  DROP ROLLBACK SEGMENT rbs01;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章