麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Oracle > 正文

Oracle行級鎖的特殊用法簡析

2024-08-29 13:55:45
字體:
來源:轉載
供稿:網友
Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點介紹Oracle行級鎖,Oracle行級鎖只對用戶正在訪問的行進行鎖定。可以更好的保證數據的安全性。
如果該用戶正在修改某行,那么其他用戶就可以更新同一表中該行之外的數據。
Oracle行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。
在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 語句時,Oracle會自動應用Oracle行級鎖行級鎖鎖定。SELECT...FOR UPDATE 語句允許用戶每次選擇多行記錄進行更新,這些記錄會被鎖定,且只能由發起查詢的用戶進行編輯。只有在回滾或提交事務之后,鎖定才會釋放,其他用戶才可以編輯這些記錄。
SELECT...FOR UPDATE 語句的語法如下:

復制代碼 代碼如下:


SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];


其中:
OF 子句用于指定即將更新的列,即鎖定行上的特定列。
WAIT 子句指定等待其他用戶釋放鎖的秒數,防止無限期的等待。
“使用FOR UPDATE WAIT”子句的優點如下:
⒈防止無限期地等待被鎖定的行;
⒉允許應用程序中對鎖的等待時間進行更多的控制。
⒊對于交互式應用程序非常有用,因為這些用戶不能等待不確定
4. 若使用了skip locked,則可以越過鎖定的行,不會報告由wait n 引發的‘資源忙'異常報告
示例:

復制代碼 代碼如下:


create table t(a varchar2(20),b varchar2(20)); insert into t values('1','1'); insert into t values('2','2'); insert into t values('3','3'); insert into t values('4','4');


現在執行如下操作:
在plsql develope中打開兩個sql窗口,
在1窗口中運行sql

復制代碼 代碼如下:


select * from t where a='1' for update;


在2窗口中運行sql1

復制代碼 代碼如下:


1. select * from t where a='1';


這一點問題也沒有,因為行級鎖不會影響純粹的select語句
再運行sql2

復制代碼 代碼如下:


2. select * from t where a='1' for update;


則這一句sql在執行時,永遠處于等待狀態,除非窗口1中sql被提交或回滾。
如何才能讓sql2不等待或等待指定的時間呢? 我們再運行sql3
3

復制代碼 代碼如下:


select * from t where a='1' for update nowait;


則在執行此sql時,直接報資源忙的異常。
若執行

復制代碼 代碼如下:


select * from t where a='1' for update wait 6;


則在等待6秒后,報 資源忙的異常。
如果我們執行sql4
4.

復制代碼 代碼如下:


select * from t where a='1' for update nowait skip Locke d;


則執行sql時,即不等待,也不報資源忙異常。
現在我們看看執行如下操作將會發生什么呢?
在窗口1中執行:
select * from t where rownum 《3 nowait skip Locked; 在窗口2中執行:
select * from t where rownum《6 nowait skip Locked;
select for update 也就如此了吧,insert、update、delete操作默認加行級鎖,其原理和操作與select for update并無兩樣。
select for update of,這個of子句在牽連到多個表時,具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩毛片免费观看 | www国产成人免费观看视频,深夜成人网 | 欧美中文字幕一区二区三区亚洲 | 超碰在线97国产 | 欧美成人午夜 | 999久久国产 | 中文字幕亚洲一区二区三区 | 成人av一二三区 | 99精品视频免费看 | 亚洲福利视频52 | 欧美1区2区在线观看 | 国产91中文字幕 | 欧美三级日本三级少妇99 | 91成人一区| 一级黄色av电影 | 黄色毛片一级视频 | 美国一级黄色毛片 | 成人在线视频精品 | 欧美亚洲综合网 | 成人在线视频黄色 | 国产免费视频一区二区裸体 | 日本aaa一级片 | 久久久久久久黄色片 | 午夜久久久精品一区二区三区 | 羞羞答答视频 | 成人18在线| 日本在线播放一区二区三区 | 久草成人在线观看 | 亚洲一级片免费观看 | 久久久久久久久久久久网站 | 欧美日韩成人一区二区 | 二区三区四区视频 | 九九精品在线观看 | 亚洲无限资源 | 成年免费大片黄在线观看岛国 | 娇妻被各种姿势c到高潮小说 | 国产美女自拍av | 国产毛片在线看 | 成人黄色网战 | av在线一区二区三区四区 | 久久综合狠狠综合久久 |