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

Oracle存儲過程中如何正確使用行鎖

數據庫 Oracle
以下的文章主要是對Oracle存儲過程中正確使用行鎖的示例介紹,以下就是其相關內容的介紹,希望你瀏覽之后會有所收獲。

以下的文章主要是講述Oracle存儲過程中如何正確的使用行鎖的實際示例,如果一張入庫單表中的相關字段status用來記錄相關的入庫狀態,入庫前我們要先判斷其入庫的標識。如果沒有入庫的話,我們則做入庫的相關處理。

否則則做另一個操作,問題來了,當兩個人同時做入庫處理時,取得的狀態都為'未入庫',于是,你可以想到,發生了兩次入庫操作。在并發問題中,一不小心就可能出現一些不易發現的錯誤。這里可以通過一個Oracle存儲過程中使用行鎖來解決這個問題,通過鎖,使該存儲過程不能同時被兩個線程調用來處理同一條記錄。

 

  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;  

 

開始事務

執行業務邏輯

修改入庫標志

提交事務

若出異常,回滾

 

  1. end P1; 

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

SELECT...FOR UPDATE 語句的語法如下:

 

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

其中:

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

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

“使用FOR UPDATE WAIT”子句的優點如下:

1防止無限期地等待被鎖定的行;

2允許應用程序中對Oracle存儲過程中使用行鎖的等待時間進行更多的控制。

3對于交互式應用程序非常有用,因為這些用戶不能等待不確定

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窗口中運行sql1q

1.

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

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

再運行sql2

2.

  1. 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時,直接報資源忙的異常。

若執行

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

則在等待6秒后,報 資源忙的異常。

如果我們執行sql4

4.

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

則執行sql時,即不等待,也不報資源忙異常。

現在我們看看執行如下操作將會發生什么呢?

在窗口1中執行:

 

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

在窗口2中執行:

 

  1. 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存儲過程中使用行鎖定。

【編輯推薦】

  1. Oracle 外鍵的相關約束中級聯刪除的方案
  2. Oracle 數據庫的各種不同版本的差別
  3. Oracle用戶的相關授權和管理的分析
  4. Oracle查詢優化4大方面的主要途徑
  5. Oracle數據庫的類型LONG功能的介紹
責任編輯:佚名 來源: 互聯網
相關推薦

2010-04-29 17:31:56

Oracle存儲過程

2010-04-23 13:45:14

Oracle存儲過程

2010-05-05 17:19:32

Oracle存儲過程

2011-04-11 17:28:50

oracle存儲select語句

2010-05-10 10:46:07

Oracle存儲過程

2011-04-12 11:12:20

Oracle存儲過程

2010-04-15 16:54:31

Oracle存儲過程

2010-05-07 13:03:01

Oracle通過存儲過

2010-08-05 14:24:37

DB2存儲過程

2010-04-16 09:03:28

Oracle 存儲過程

2010-05-05 14:55:15

Oracle存儲過程

2010-05-07 18:44:28

Oracle存儲過程

2010-04-16 10:24:17

Oracle存儲過程

2010-04-30 14:22:43

Oracle通過

2011-08-11 14:35:47

SQL Server插入更新

2011-04-15 10:56:22

2010-03-30 13:19:57

Oracle存儲

2010-05-05 11:06:32

Oracle存儲過程

2010-04-23 13:29:01

Oracle存儲過程

2010-04-15 17:20:54

Oracle存儲過程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 玖玖视频免费 | 精品成人av | 国产成人一区二区 | 国产91丝袜在线18 | 黄色欧美在线 | 欧美午夜一区 | 日韩欧美一区二区三区四区 | 日本高清视频在线播放 | 日韩成人精品一区 | 日韩中文在线视频 | 亚洲大片 | 精品在线免费观看视频 | 成人免费看片 | 成人福利网 | 男女啪啪高潮无遮挡免费动态 | 亚洲精品乱码久久久久久蜜桃91 | 久久久免费电影 | 中文字幕精品视频 | 欧美 日韩 视频 | 久久久99精品免费观看 | 国内久久 | 精精国产xxxx视频在线播放 | 国产精品福利在线 | 久久高清免费视频 | 日韩一区二区三区在线视频 | 成人性视频免费网站 | 综合九九| 国产精品69av | 国产精品99久久久久久宅男 | 久久久久无码国产精品一区 | 久久精品a级毛片 | 日韩一区av | 国产精品一区二区久久 | 91精品国产92 | av网站观看 | 亚洲国产精品久久久久秋霞不卡 | 一级在线观看 | 亚洲一区 | 成人性生交大免费 | 中文字幕在线第一页 | 凹凸日日摸日日碰夜夜 |