1、首先在執(zhí)行Update時,Oracle就地更新,如出現(xiàn)原block空間不足的情況,通過link的方式鏈接至新block上。
創(chuàng)新互聯(lián)自2013年創(chuàng)立以來,先為鐵力等服務(wù)建站,鐵力等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為鐵力企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
2、其次PG的Update,不是原地更新,而是保留原有數(shù)據(jù),通過新增新的tuple保存新增數(shù)據(jù),原有數(shù)據(jù)通過Vacuum機制清理。
3、最后Vacuum機制需要滿足MVCC的要求,在某些情況下,不會清理垃圾數(shù)據(jù),在事務(wù)繁忙的時候?qū)е聲е聰?shù)據(jù)表空間不斷增長。
execute執(zhí)行后 可以回滾
commit提交后 不可以回滾
其實Oracle提交數(shù)據(jù)是分兩步操作的,第一步execute執(zhí)行,第二步commit提交。對應的PL\SQL也是要先點execute執(zhí)行,執(zhí)行后再點commit提交。
但是 commit提交后 可以用閃回查詢恢復原來的數(shù)據(jù) 因為oracle會將近期的數(shù)據(jù)保存到快照中 如:
SELECT * FROM TABLE_1 AS OF TIMESTAMP TO_TIMESTAMP('20080606 20:00:00','YYYYMMDD HH24:MI:SS');
這里'20080606 20:00:00'就是你想恢復數(shù)據(jù)到哪個時間狀態(tài) TABLE_1是數(shù)據(jù)庫的表名 這樣查詢到的數(shù)據(jù)就是執(zhí)行更新操作之前的數(shù)據(jù)
execute執(zhí)行后
可以回滾
commit提交后
不可以回滾
其實oracle提交數(shù)據(jù)是分兩步操作的,第一步execute執(zhí)行,第二步commit提交。對應的pl\sql也是要先點execute執(zhí)行,執(zhí)行后再點commit提交。
但是
commit提交后
可以用閃回查詢恢復原來的數(shù)據(jù)
因為oracle會將近期的數(shù)據(jù)保存到快照中
如:
select
*
from
table_1
as
of
timestamp
to_timestamp('20080606
20:00:00','yyyymmdd
hh24:mi:ss');
這里'20080606
20:00:00'就是你想恢復數(shù)據(jù)到哪個時間狀態(tài)
table_1是數(shù)據(jù)庫的表名
這樣查詢到的數(shù)據(jù)就是執(zhí)行更新操作之前的數(shù)據(jù)
execute執(zhí)行后
可以回滾
commit提交后
不可以回滾
其實Oracle提交數(shù)據(jù)是分兩步操作的,第一步execute執(zhí)行,第二步commit提交。對應的PL\SQL也是要先點execute執(zhí)行,執(zhí)行后再點commit提交。
但是
commit提交后
可以用閃回查詢恢復原來的數(shù)據(jù)
因為oracle會將近期的數(shù)據(jù)保存到快照中
如:
SELECT
*
FROM
TABLE_1
AS
OF
TIMESTAMP
TO_TIMESTAMP('20080606
20:00:00','YYYYMMDD
HH24:MI:SS');
這里'20080606
20:00:00'就是你想恢復數(shù)據(jù)到哪個時間狀態(tài)
TABLE_1是數(shù)據(jù)庫的表名
這樣查詢到的數(shù)據(jù)就是執(zhí)行更新操作之前的數(shù)據(jù)
回滾段管理一直是ORACLE數(shù)據(jù)庫管理的一個難題 本文通過實例介紹ORACLE回滾段的概念 用法和規(guī)劃及問題的解決 回滾段概述回滾段用于存放數(shù)據(jù)修改之前的值(包括數(shù)據(jù)修改之前的位置和值) 回滾段的頭部包含正在使用的該回滾段事務(wù)的信息 一個事務(wù)只能使用一個回滾段來存放它的回滾信息 而一個回滾段可以存放多個事務(wù)的回滾信息 回滾段的作用事務(wù)回滾 當事務(wù)修改表中數(shù)據(jù)的時候 該數(shù)據(jù)修改前的值(即前影像)會存放在回滾段中 當用戶回滾事務(wù)(ROLLBACK)時 ORACLE將會利用回滾段中的數(shù)據(jù)前影像來將修改的數(shù)據(jù)恢復到原來的值 事務(wù)恢復 當事務(wù)正在處理的時候 例程失敗 回滾段的信息保存在重做日志文件中 ORACLE將在下次打開數(shù)據(jù)庫時利用回滾來恢復未提交的數(shù)據(jù) 讀一致性 當一個會話正在修改數(shù)據(jù)時 其他的會話將看不到該會話未提交的修改 而且 當一個語句正在執(zhí)行時 該語句將看不到從該語句開始執(zhí)行后的未提交的修改(語句級讀一致性) 當ORACLE執(zhí)行SELECT語句時 ORACLE依照當前的系統(tǒng)改變號(SYSTEM CHANGE NUMBER SCN)來保證任何前于當前SCN的未提交的改變不被該語句處理 可以想象 當一個長時間的查詢正在執(zhí)行時 若其他會話改變了該查詢要查詢的某個數(shù)據(jù)塊 ORACLE將利用回滾段的數(shù)據(jù)前影像來構(gòu)造一個讀一致性視圖 事務(wù)級的讀一致性O(shè)RACLE一般提供SQL語句級(SQL STATEMENT LEVEL)的讀一致性 可以用以下語句來實現(xiàn)事務(wù)級的讀一致性 SET TRANSACTION READ ONLY 或 SET TANNSACTION SERIALIZABLE 以上兩個語句都將在事務(wù)開始后提供讀一致性 需要注意的是 使用第二個語句對數(shù)據(jù)庫的并發(fā)性和性能將帶來影響 回滾段的種類系統(tǒng)回滾段 當數(shù)據(jù)庫創(chuàng)建后 將自動創(chuàng)建一個系統(tǒng)回滾段 該回滾段只用于存放系統(tǒng)表空間中對象的前影像 非系統(tǒng)回滾段 擁有多個表空間的數(shù)據(jù)庫至少應該有一個非系統(tǒng)回滾段 用于存放非系統(tǒng)表空間中對象的數(shù)據(jù)前影像 非系統(tǒng)回滾段又分為私有回滾段和公有回滾段 私有回滾段應在參數(shù)文件的ROLLBACK SEGMENTS參數(shù)中列出 以便例程啟動時自動使其在線(ONLINE) 公有回滾段一般在OPS(ORACLE并行服務(wù)器)中出現(xiàn) 將在例程啟動時自動在線 DEFERED回滾段 該回滾段在表空間離線(OFFLINE)時由系統(tǒng)自動創(chuàng)建 當表空間再次在線(ONLINE)時由系統(tǒng)自動刪除 用于存放表空間離線時產(chǎn)生的回滾信息 回滾段的使用分配回滾段 當事務(wù)開始時 ORACLE將為該事務(wù)分配回滾段 并將擁有最少事務(wù)的回滾段分配給該事務(wù) 事務(wù)可以用以下語句申請指定的回滾段 SET TRANSTRACTION USE ROLLBACK SEGMENT rollback_segment事務(wù)將以順序 循環(huán)的方式使用回滾段的區(qū)(EXTENTS) 當當前區(qū)用滿后移到下一個區(qū) 幾個事務(wù)可以寫在回滾段的同一個區(qū) 但每個回滾段的塊只能包含一個事務(wù)的信息 例如(兩個事務(wù)使用同一個回滾段 該回滾段有四個區(qū)) 事務(wù)在進行中 它們正在使用回滾段的第三個區(qū) 當兩個事務(wù)產(chǎn)生更多的回滾信息 它們將繼續(xù)使用第三個區(qū) 當?shù)谌齻€區(qū)滿后 事務(wù)將寫到第四個區(qū) 當事務(wù)開始寫到一個新的區(qū)時 稱為翻轉(zhuǎn)(WRAP) 當?shù)谒膫€區(qū)用滿時 如果第一個區(qū)是空閑或非活動(使用該區(qū)的所有事務(wù)完成而沒有活動的事務(wù))的 事務(wù)將接著使用第一個區(qū) 回滾段的擴張(EXTEND)當當前回滾段區(qū)的所有塊用完而事務(wù)還需要更多的回滾空間時 回滾段的指針將移到下一個區(qū) 當最后一個區(qū)用完 指針將移到第一個區(qū)的前面 回滾段指針移到下一個區(qū)的前提是下一個區(qū)沒有活動的事務(wù) 同時指針不能跨區(qū) 當下一個區(qū)正在使用時 事務(wù)將為回滾段分配一個新的區(qū) 這種分配稱為回滾段的擴展 回滾段將一直擴展到該回滾段區(qū)的個數(shù)到達回滾段的參數(shù)MAXEXTENTS的值時為止 回滾段的回收和OPTIMAL參數(shù)OPTIMAL參數(shù)指明回滾段空閑時收縮到的位置 指明回滾段的OPTIMAL參數(shù)可以減少回滾段空間的浪費 創(chuàng)建回滾段語法 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}]) ]注 回滾段可以在創(chuàng)建時指明PRIVATE或PUBLIC 一旦創(chuàng)建將不能修改 MINEXTENTS 必須大于等于 PCTINCREASE必須是 OPTIMAL如果要指定 必須大于等于回滾段的初始大?。ㄓ蒑INEXTENTS指定)建議 一般情況下 INITIAL=NEXT設(shè)置OPTIMAL參數(shù)來節(jié)約空間的使用不要設(shè)置MAXEXTENTS為UNLIMITED回滾段應創(chuàng)建在一個特定的回滾段表空間內(nèi)例 CREATE ROLLBACK SEGMENT rbs TABLESPACE rbs STORAGE ( INITIAL K NEXT K MINEXTENTS MAXEXTENTS OPTIMAL K);使回滾段在線當回滾段創(chuàng)建后 回滾段是離線的 不能被數(shù)據(jù)庫使用 為了使回滾段被事務(wù)利用 必須將回滾段在線 可以用以下命令使回滾段在線 ALTER ROLLBACK SEGMENT rollback_segment ONLINE;例 ALTER ROLLBACK SEGMENT rbs ONLINE 為了使回滾段在數(shù)據(jù)庫啟動時自動在線 可以在數(shù)據(jù)庫的參數(shù)文件中列出回滾段的名字 例如在參數(shù)文件中加入以下一行 ROLLBACK_SEGMENT=(rbs rbs )修改回滾段的存儲參數(shù)可以使用ALTER ROLLBACK SEGMENT命令修改回滾段的存儲參數(shù)(包括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 rbs STORAGE (MAXEXTENTS );回收回滾段的空間如果指定了回滾段的OPTIMAL參數(shù) ORACLE將自動回收回滾段到OPTIMAL指定的位置 用戶也可以手動回收回滾段的空間 語法 ALTER ROLLBACK SEGMENT rollback_segment SHRINK [TO integer [K|M]];說明 如果不指明TO integer的數(shù)值 ORACLE將試圖回收到OPTIMAL的位置 例 ALTER ROLLBACK SEGMENT rbs SHRINK TO M;使回滾段離線為了達到以下兩個目的將要回滾段離線 阻止新的事務(wù)使用該回滾段 該回滾段必須刪除 語法 ALTER ROLLBACK SEGMENT rollback_segment OFFLINE;例 ALTER ROLLBACK SEGMENT rbs OFFLINE;說明 如果有事務(wù)正在使用該回滾段 運行該命令后 回滾段的狀態(tài)將是PENDING OFFLINE 事務(wù)結(jié)束后 狀態(tài)將改為OFFLINE 可以通過V$ROLLSTAT查詢回滾段的狀態(tài) 刪除回滾段當回滾段不再需要或要重建以改變INITIAL NEXT或MINEXTENTS參數(shù)時 可以將其刪除 要刪除回滾段 不許使該回滾段離線 語法 DROP ROLLBACK SEGMENT rollback_segment;例 DROP ROLLBACK SEGMENT rbs ;查詢回滾段的信息所用數(shù)據(jù)字典 DBA_ROLLBACK_SEGS可以查詢的信息 回滾段的標識(SEGMENT_ID) 名稱(SEGMENT_NAME) 所在表空間(TABLESPACE_NAME) 類型(OWNER) 狀態(tài)(STATUS) 例 SQLSELECT segment_name tablespace_name owner status FROM dba_rollback_segs;回滾段的統(tǒng)計信息數(shù)據(jù)字典 V$ROLLNAME V$ROLLSTAT例 SQLSELECT n name s extents s rssize s optsize s hwmsize s xacts s statusFROM v$rollname n v$rollstat sWHERE n usn=s usn;回滾段的當前活動事務(wù)數(shù)據(jù)字典 V$SESSION V$TRANSACTION例 SQLSELECT s username t xidusn t ubafil t ubablk t used_ublkFROM v$session s v$transaction tWHERE s saddr=t ses_addr; USERNAMEXIDUSN UBAFIL UBABLKUSED_UBLK SYSTEM SCOTT lishixinzhi/Article/program/Oracle/201311/18942