免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
oracle事務中的保存點

用戶在事務(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 語句也會被完全回滾)。

 

本站僅提供存儲服務,所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
數(shù)據(jù)庫事務
Oracle PL/SQL開發(fā)基礎(第二十七彈:事務處理簡介)
Oracle數(shù)據(jù)操作和控制語言詳解(2)
第四章 事務管理
Oracle怎么顯式開啟事務,開始事務跟鎖有什么關系,在存儲過程中有時怎么開啟和提交,回滾事務的
Transaction Management
更多類似文章 >>
生活服務
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服