佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Oracle行級(jí)鎖的特殊用法簡(jiǎn)析

Oracle行級(jí)鎖的特殊用法簡(jiǎn)析

熱門標(biāo)簽:呼叫中心市場(chǎng)需求 鐵路電話系統(tǒng) 百度競(jìng)價(jià)排名 AI電銷 網(wǎng)站排名優(yōu)化 Linux服務(wù)器 服務(wù)外包 地方門戶網(wǎng)站
Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點(diǎn)介紹Oracle行級(jí)鎖,Oracle行級(jí)鎖只對(duì)用戶正在訪問的行進(jìn)行鎖定。可以更好的保證數(shù)據(jù)的安全性。
如果該用戶正在修改某行,那么其他用戶就可以更新同一表中該行之外的數(shù)據(jù)。
Oracle行級(jí)鎖是一種排他鎖,防止其他事務(wù)修改此行,但是不會(huì)阻止讀取此行的操作。
在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 語句時(shí),Oracle會(huì)自動(dòng)應(yīng)用Oracle行級(jí)鎖行級(jí)鎖鎖定。SELECT...FOR UPDATE 語句允許用戶每次選擇多行記錄進(jìn)行更新,這些記錄會(huì)被鎖定,且只能由發(fā)起查詢的用戶進(jìn)行編輯。只有在回滾或提交事務(wù)之后,鎖定才會(huì)釋放,其他用戶才可以編輯這些記錄。
SELECT...FOR UPDATE 語句的語法如下:
復(fù)制代碼 代碼如下:

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

其中:
OF 子句用于指定即將更新的列,即鎖定行上的特定列。
WAIT 子句指定等待其他用戶釋放鎖的秒數(shù),防止無限期的等待。
“使用FOR UPDATE WAIT”子句的優(yōu)點(diǎn)如下:
⒈防止無限期地等待被鎖定的行;
⒉允許應(yīng)用程序中對(duì)鎖的等待時(shí)間進(jìn)行更多的控制。
⒊對(duì)于交互式應(yīng)用程序非常有用,因?yàn)檫@些用戶不能等待不確定
4. 若使用了skip locked,則可以越過鎖定的行,不會(huì)報(bào)告由wait n 引發(fā)的‘資源忙'異常報(bào)告
示例:
復(fù)制代碼 代碼如下:

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');

現(xiàn)在執(zhí)行如下操作:
在plsql develope中打開兩個(gè)sql窗口,
在1窗口中運(yùn)行sql
復(fù)制代碼 代碼如下:

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

在2窗口中運(yùn)行sql1
復(fù)制代碼 代碼如下:

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

這一點(diǎn)問題也沒有,因?yàn)樾屑?jí)鎖不會(huì)影響純粹的select語句
再運(yùn)行sql2
復(fù)制代碼 代碼如下:

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

則這一句sql在執(zhí)行時(shí),永遠(yuǎn)處于等待狀態(tài),除非窗口1中sql被提交或回滾。
如何才能讓sql2不等待或等待指定的時(shí)間呢? 我們?cè)龠\(yùn)行sql3
3
復(fù)制代碼 代碼如下:

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

則在執(zhí)行此sql時(shí),直接報(bào)資源忙的異常。
若執(zhí)行
復(fù)制代碼 代碼如下:

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

則在等待6秒后,報(bào) 資源忙的異常。
如果我們執(zhí)行sql4
4.
復(fù)制代碼 代碼如下:

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

則執(zhí)行sql時(shí),即不等待,也不報(bào)資源忙異常。
現(xiàn)在我們看看執(zhí)行如下操作將會(huì)發(fā)生什么呢?
在窗口1中執(zhí)行:
select * from t where rownum 《3 nowait skip Locked; 在窗口2中執(zhí)行:
select * from t where rownum《6 nowait skip Locked;
select for update 也就如此了吧,insert、update、delete操作默認(rèn)加行級(jí)鎖,其原理和操作與select for update并無兩樣。
select for update of,這個(gè)of子句在牽連到多個(gè)表時(shí),具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關(guān)行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關(guān)的表的行才會(huì)被鎖定。
您可能感興趣的文章:
  • 查看Oracle中是否有鎖表的sql
  • 在命令行下進(jìn)行Oracle用戶解鎖的語句
  • 深入探討:Oracle中如何查詢正鎖表的用戶以及釋放被鎖的表的方法
  • ORACLE 如何查詢被鎖定表及如何解鎖釋放session
  • Oracle數(shù)據(jù)庫賬號(hào)被鎖定解決方法
  • oracle查詢鎖表與解鎖情況提供解決方案
  • Oracle 添加用戶并賦權(quán),修改密碼,解鎖,刪除用戶的方法
  • Oracle阻塞(blockingblocked)實(shí)例詳解

標(biāo)簽:蘭州 湖南 黃山 崇左 銅川 仙桃 湘潭 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle行級(jí)鎖的特殊用法簡(jiǎn)析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    永善县| 赤壁市| 成安县| 烟台市| 邹平县| 彭泽县| 六安市| 河津市| 屯留县| 宜兰市| 方城县| 武宁县| 潜山县| 静宁县| 公安县| 北京市| 栾川县| 龙南县| 黄冈市| 白河县| 怀柔区| 图片| 张家口市| 长顺县| 工布江达县| 营口市| 山西省| 扶风县| 巴彦淖尔市| 陈巴尔虎旗| 兴化市| 武川县| 右玉县| 绍兴市| 泸定县| 巨野县| 英吉沙县| 永新县| 英山县| 康马县| 日喀则市|