日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Oracle存儲(chǔ)過(guò)程中如何正確使用行鎖

以下的文章主要是講述Oracle存儲(chǔ)過(guò)程中如何正確的使用行鎖的實(shí)際示例,如果一張入庫(kù)單表中的相關(guān)字段status用來(lái)記錄相關(guān)的入庫(kù)狀態(tài),入庫(kù)前我們要先判斷其入庫(kù)的標(biāo)識(shí)。如果沒(méi)有入庫(kù)的話,我們則做入庫(kù)的相關(guān)處理。

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供臨川網(wǎng)站建設(shè)、臨川做網(wǎng)站、臨川網(wǎng)站設(shè)計(jì)、臨川網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、臨川企業(yè)網(wǎng)站模板建站服務(wù),十余年臨川做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

否則則做另一個(gè)操作,問(wèn)題來(lái)了,當(dāng)兩個(gè)人同時(shí)做入庫(kù)處理時(shí),取得的狀態(tài)都為'未入庫(kù)',于是,你可以想到,發(fā)生了兩次入庫(kù)操作。在并發(fā)問(wèn)題中,一不小心就可能出現(xiàn)一些不易發(fā)現(xiàn)的錯(cuò)誤。這里可以通過(guò)一個(gè)Oracle存儲(chǔ)過(guò)程中使用行鎖來(lái)解決這個(gè)問(wèn)題,通過(guò)鎖,使該存儲(chǔ)過(guò)程不能同時(shí)被兩個(gè)線程調(diào)用來(lái)處理同一條記錄。

 
 
 
  1. create or replace procedure P1(pdm in varchar2) is  
  2. var_flag char(1);  
  3. begin  
  4. select status into var_flag from #T where dm=pdm for update wait 5;  

開(kāi)始事務(wù)

執(zhí)行業(yè)務(wù)邏輯

修改入庫(kù)標(biāo)志

提交事務(wù)

若出異常,回滾

 
 
 
  1. end P1; 

注意:記錄被鎖定之后不可以在該記錄上做操作。

SELECT...FOR UPDATE 語(yǔ)句的語(yǔ)法如下:

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

其中:

OF 子句用于指定即將更新的列,即鎖定行上的特定列。

WAIT 子句指定等待其他用戶釋放鎖的秒數(shù),防止無(wú)限期的等待。

“使用FOR UPDATE WAIT”子句的優(yōu)點(diǎn)如下:

1防止無(wú)限期地等待被鎖定的行;

2允許應(yīng)用程序中對(duì)Oracle存儲(chǔ)過(guò)程中使用行鎖的等待時(shí)間進(jìn)行更多的控制。

3對(duì)于交互式應(yīng)用程序非常有用,因?yàn)檫@些用戶不能等待不確定

4 若使用了skip locked,則可以越過(guò)鎖定的行,不會(huì)報(bào)告由wait n 引發(fā)的‘資源忙’異常報(bào)告

示例:

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

現(xiàn)在執(zhí)行如下操作:

在plsql develope中打開(kāi)兩個(gè)sql窗口,

在1窗口中運(yùn)行sql

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

在2窗口中運(yùn)行sql1q

1.

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

這一點(diǎn)問(wèn)題也沒(méi)有,因?yàn)樾屑?jí)鎖不會(huì)影響純粹的select語(yǔ)句

再運(yùn)行sql2

2.

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

則這一句sql在執(zhí)行時(shí),永遠(yuǎn)處于等待狀態(tài),除非窗口1中sql被提交或回滾。

如何才能讓sql2不等待或等待指定的時(shí)間呢? 我們?cè)龠\(yùn)行sql3

3.

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

則在執(zhí)行此sql時(shí),直接報(bào)資源忙的異常。

若執(zhí)行

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

則在等待6秒后,報(bào) 資源忙的異常。

如果我們執(zhí)行sql4

4.

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

則執(zhí)行sql時(shí),即不等待,也不報(bào)資源忙異常。

現(xiàn)在我們看看執(zhí)行如下操作將會(huì)發(fā)生什么呢?

在窗口1中執(zhí)行:

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

在窗口2中執(zhí)行:

 
 
 
  1. select * from t where rownum<=6 nowait skip Locked; 

select for update 也就如此了吧,insert、update、delete操作默認(rèn)加行級(jí)鎖,其原理和操作與select for update并無(wú)兩樣。

select for update of,這個(gè)of子句在牽連到多個(gè)表時(shí),具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關(guān)行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關(guān)的表的行才會(huì)被Oracle存儲(chǔ)過(guò)程中使用行鎖定。


文章名稱:Oracle存儲(chǔ)過(guò)程中如何正確使用行鎖
分享地址:http://www.5511xx.com/article/dpehees.html