成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談Oracle行級鎖的特殊用法

數據庫 Oracle
Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點介紹Oracle行級鎖,Oracle行級鎖只對用戶正在訪問的行進行鎖定。可以更好的保證數據的安全性。

Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點介紹Oracle行級鎖,Oracle行級鎖只對用戶正在訪問的行進行鎖定。可以更好的保證數據的安全性。

如果該用戶正在修改某行,那么其他用戶就可以更新同一表中該行之外的數據。
Oracle行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。
在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 語句時,Oracle會自動應用Oracle行級鎖行級鎖鎖定。SELECT...FOR UPDATE 語句允許用戶每次選擇多行記錄進行更新,這些記錄會被鎖定,且只能由發起查詢的用戶進行編輯。只有在回滾或提交事務之后,鎖定才會釋放,其他用戶才可以編輯這些記錄。
SELECT...FOR UPDATE 語句的語法如下:

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

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

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

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

  1. 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

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

則在執行此sql時,直接報資源忙的異常。
若執行 select * from t where a='1' for update wait 6; 則在等待6秒后,報 資源忙的異常。
如果我們執行sql4

4.

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

d; 則執行sql時,即不等待,也不報資源忙異常。
現在我們看看執行如下操作將會發生什么呢?
在窗口1中執行:

  1. select * from t where rownum 《3 nowait skip Locked;   

在窗口2中執行:

  1. select * from t where rownum《6 nowait skip Locked;   
  2. select for update 

也就如此了吧,insert、update、delete操作默認加行級鎖,其原理和操作與select for update并無兩樣。
select for update of,這個of子句在牽連到多個表時,具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。

【編輯推薦】

  1. 修改Oracle存儲過程所需代碼
  2. 對Oracle存儲過程的總結
  3. 實現Oracle存儲過程的實際應用的代碼 
  4. 深入高性能的Oracle動態SQL開發 
  5. Oracle SQL的優化規則解析 
責任編輯:佚名 來源: my god
相關推薦

2010-05-24 12:50:59

MySQL表級鎖

2024-11-29 07:38:12

MySQL數據庫

2024-05-13 12:44:00

InnodbMySQL行級鎖

2020-02-06 10:02:45

MySQL數據庫全局鎖

2010-11-22 14:42:13

MySQL行級鎖

2022-10-24 00:33:59

MySQL全局鎖行級鎖

2010-10-15 14:10:56

Mysql行級鎖

2023-08-26 11:32:07

2024-12-18 07:40:50

MySQL機制

2010-07-13 16:20:30

SQL Server數

2011-06-09 15:15:52

RAII

2010-10-27 15:03:47

Oracle with

2009-05-06 11:09:10

Oracle物化視圖數據庫

2010-04-26 10:09:22

Oracle存儲過程

2009-05-04 09:52:49

Oracle優化排序

2021-01-15 05:12:14

Java并發樂觀鎖

2009-11-17 17:47:56

Oracle Shar

2010-06-29 17:17:44

SQL Server鎖

2010-11-24 15:53:11

MySQL中SELEC

2022-09-13 09:31:59

Python內置函數lambda
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产伦一区二区三区久久 | 欧美一区视频 | 欧美日韩一区精品 | 日本天天操 | 久久久精品久久久 | 亚洲第一av| 成人免费视频网站在线看 | 国产精品亚洲一区二区三区在线观看 | 久久久久精 | 97精品国产| 欧美一区二区三区 | 成人免费观看视频 | 欧美日韩大片 | 美女黄色在线观看 | 91在线一区 | 中文字幕av一区 | 中文亚洲字幕 | 伊人久久精品 | 成人欧美一区二区 | 久久精品久久久 | 91视频免费在观看 | 九九热在线免费观看 | 在线一区视频 | 三级黄色片在线观看 | 国产精品成人国产乱一区 | 中文字幕乱码一区二区三区 | 成人国产精品久久久 | 欧美日韩电影一区二区 | 日韩精品在线一区 | 亚洲免费在线观看视频 | 亚洲最色网站 | 精品久久免费 | 亚洲视频免费在线看 | jlzzxxxx18hd护士 | 伊人欧美视频 | 99久久精品免费 | 91精品国产91久久久久久 | 一区二区三区小视频 | 欧美日韩一| 成人精品久久 | 日本成人三级电影 |