ORACLE回滾段(1)
建立回滾段
語法:
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 2M;
使回滾段離線
為了達到以下兩個目的將要回滾段離線:
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; [@more@]
語法:
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 2M;
使回滾段離線
為了達到以下兩個目的將要回滾段離線:
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; [@more@]
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/18921899/viewspace-1017693/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【UNDO】Oracle系統回滾段說明Oracle
- oracle回滾溯源Oracle
- Oracle 資料回滾Oracle
- 深入UNDO回滾段,檢視爭用以及回滾段使用量的估算
- [20140516]取出回滾段資訊.txt
- 利用oracle的日誌挖掘實現回滾Oracle
- Oracle查詢回滾大事務所需時間Oracle
- 關於ORACLE大型事務回滾的幾個點Oracle
- 引數fast_start_parallel_rollback調整oracle回滾的速度ASTParallelOracle
- 入門Kubernetes - 滾動升級/回滾
- Kubernetes:更新與回滾
- Spring Boot 事物回滾Spring Boot
- 1分鐘搞定 Nginx 版本的平滑升級與回滾Nginx
- 回滾與撤銷(一)
- Kubernetes:Pod 升級、回滾
- Oracle vs PostgreSQL,研發注意事項(3)- 事務回滾之UPDATE操作解析OracleSQL
- 談談 Git 程式碼回滾Git
- [20181222]如何找出回滾操作.txt
- Spring的事物回滾問題Spring
- 回滾莫隊學習筆記筆記
- Oracle閃回技術 為Oracle閃回配置資料庫Oracle資料庫
- 1_深入解析Oracle ASSM 段頭塊(PAGETABLE SEGMENT HEADER)結構OracleSSMHeader
- 實踐資料回滾解決方案
- spring boot 顯示處理事務回滾Spring Boot
- Git回滾程式碼到某個commitGitMIT
- sqlserver遇到回滾事務的操作策略SQLServer
- IDEA程式碼不想提交了,如何回滾Idea
- git遠端分支回滾到指定版本Git
- 關於事務回滾註解@Transactional
- 【RECO_ORACLE】Oracle閃回PDB的方法Oracle
- BZOJ4241: 歷史研究(回滾莫隊)
- Spring Data JPA中事務回滾意外RollbackExceptionSpringException
- MySQL死鎖案例一(回滾導致死鎖)MySql
- 拉鍊表的建立、查詢和回滾
- 淺入Kubernetes(12):Deployment 的升級、回滾
- MySQL實現事務的提交和回滾MySql
- 不能回滾的Redis事務還能用嗎Redis
- Win10系統怎麼設定回滾時間 win10系統設定回滾時間的方法Win10
- oracle打補丁回顧Oracle