婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Oracle行級鎖的特殊用法簡析

Oracle行級鎖的特殊用法簡析

熱門標簽:地圖標注付款了怎么找不到了 貴陽智能電銷機器人官網 外呼系統口號 北京外呼系統公司排名 北京營銷外呼系統廠家 沈陽400電話是如何辦理 溫州人工外呼系統 百度地圖標注員是干什么 外呼系統鄭州
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中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。
您可能感興趣的文章:
  • 查看Oracle中是否有鎖表的sql
  • 在命令行下進行Oracle用戶解鎖的語句
  • 深入探討:Oracle中如何查詢正鎖表的用戶以及釋放被鎖的表的方法
  • ORACLE 如何查詢被鎖定表及如何解鎖釋放session
  • Oracle數據庫賬號被鎖定解決方法
  • oracle查詢鎖表與解鎖情況提供解決方案
  • Oracle 添加用戶并賦權,修改密碼,解鎖,刪除用戶的方法
  • Oracle阻塞(blockingblocked)實例詳解

標簽:潮州 溫州 衡水 衢州 定西 包頭 淮北 通遼

巨人網絡通訊聲明:本文標題《Oracle行級鎖的特殊用法簡析》,本文關鍵詞  Oracle,行級,鎖,的,特殊,用法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle行級鎖的特殊用法簡析》相關的同類信息!
  • 本頁收集關于Oracle行級鎖的特殊用法簡析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 阳春市| 长武县| 秦安县| 武隆县| 清镇市| 清苑县| 平果县| 昌图县| 湟中县| 侯马市| 阿图什市| 吉林省| 泽州县| 兴隆县| 霍城县| 常德市| 齐齐哈尔市| 十堰市| 报价| 苍南县| 泌阳县| 乌兰察布市| 江津市| 十堰市| 阳江市| 绍兴县| 军事| 潼南县| 梨树县| 阿尔山市| 同德县| 清丰县| 台中县| 双峰县| 寿宁县| 达拉特旗| 汾阳市| 新昌县| 商河县| 鱼台县| 曲松县|