用戶在事務(transaction)內(nèi)可以聲明(declare)被稱為保存點(savepoint)
的標記。保存點將一個大事務劃分為較小的片斷。
用戶可以使用保存點(savepoint)在事務(transaction)內(nèi)的任意位置作標
記。之后用戶在對事務進行回滾操作(rolling back)時,就可以選擇從當前
執(zhí)行位置回滾到事務內(nèi)的任意一個保存點。例如用戶可以在一系列復雜的更
新(update)操作之間插入保存點,如果執(zhí)行過程中一個語句出現(xiàn)錯誤,用
戶 可以回滾到錯誤之前的某個保存點,而不必重新提交所有的語句。
在開發(fā)應用程序時也同樣可以使用保存點(savepoint)。如果一個過程
(procedure)內(nèi)包含多個函數(shù)(function),用戶可以在每個函數(shù)的開始位置
創(chuàng)建一個保存點。當一個函數(shù)失敗時, 就很容易將數(shù)據(jù)恢復到函數(shù)執(zhí)行之前
的狀態(tài),回滾(roll back)后可以修改參數(shù)重新調(diào)用函數(shù),或執(zhí)行相關的錯誤
處理。
當事務(transaction)被回滾(rollback)到某個保存點(savepoint)后,
Oracle將釋放由被回滾語句使用的鎖。其他等待被鎖資源的事務就可以繼續(xù)
執(zhí)行。需要更新(update)被鎖數(shù)據(jù)行的事務也可以繼續(xù)執(zhí)行。
將事務(transaction)回滾(roll back)到某個保存點(savepoint)的過程如
下:
1. Oracle 回滾指定保存點之后的語句
2. Oracle 保留指定的保存點,但其后創(chuàng)建的保存點都將被清除
3. Oracle 釋放此保存點后獲得的表級鎖(table lock)與行級鎖(row
lock),但之前的數(shù)據(jù)鎖依然保留。
被部分回滾的事務(transaction)依然處于活動狀態(tài),可以繼續(xù)執(zhí)行。
一個事務(transaction)在等待其他事務的過程中,進行回滾(roll back)到
某個保存點(savepoint)的操作不會釋放行級鎖(row lock)。為了避免事務
因為不能獲得鎖而被掛起,應在執(zhí)行 UPDATE 或 DELETE 操作前使用 FOR
UPDATE ... NOWAIT 語句。(以上內(nèi)容講述的是回滾保存點之前所獲得的
鎖。而在保存點之后獲得的行級鎖是會被釋放的,同時保存點之后執(zhí)行的
SQL 語句也會被完全回滾)。