九色成人免费视频_久久一区视频_视频一区国产精品_精品视频在线观看

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

Oracle悲觀鎖和樂觀鎖淺析

發布時間:  2012/9/11 16:53:17

為了得到最大的性能,一般數據庫都有并發機制,不過帶來的問題就是數據訪問的沖突。為了解決這個問題,大多數數據庫用的方法就是數據的鎖定。

數據的鎖定分為兩種方法,第一種叫做悲觀鎖,第二種叫做樂觀鎖。什么叫悲觀鎖呢,悲觀鎖顧名思義,就是對數據的沖突采取一種悲觀的態度,也就是說假設數據肯定會沖突,所以在數據開始讀取的時候就把數據鎖定住。而樂觀鎖就是認為數據一般情況下不會造成沖突,所以在數據進行提交更新的時候,才會正式對數據的沖突與否進行檢測,如果發現沖突了,則讓用戶返回錯誤的信息,讓用戶決定如何去做。 -
 


先從悲觀鎖開始說。在SqlServer等其余很多數據庫中,數據的鎖定通常采用頁級鎖的方式,也就是說對一張表內的數據是一種串行化的更新插入機制,在任何時間同一張表只會插1條數據,別的想插入的數據要等到這一條數據插完以后才能依次插入。帶來的后果就是性能的降低,在多用戶并發訪問的時候,當對一張表進行頻繁操作時,會發現響應效率很低,數據庫經常處于一種假死狀態。而Oracle用的是行級鎖,只是對想鎖定的數據才進行鎖定,其余的數據不相干,所以在對Oracle表中并發插數據的時候,基本上不會有任何影響。

注:對于悲觀鎖是針對并發的可能性比較大,而一般在我們的應用中用樂觀鎖足以。


Oracle的悲觀鎖需要利用一條現有的連接,分成兩種方式,從SQL語句的區別來看,就是一種是for update,一種是for update nowait的形式。比如我們看一個例子。首先建立測試用的數據庫表。

CREATE TABLE TEST(ID,NAME,LOCATION,VALUE,CONSTRAINT test_pk PRIMARY KEY(ID))AS SELECT deptno, dname, loc, 1 FROM scott.dept


這里我們利用了Oracle的Sample的scott用戶的表,把數據copy到我們的test表中。首先我們看一下for update鎖定方式。首先我們執行如下的select for update語句。

select * from test where id = 10 for update

通過這條檢索語句鎖定以后,再開另外一個sql*plus窗口進行操作,再把上面這條sql語句執行一便,你會發現sqlplus好像死在那里了,好像檢索不到數據的樣子,但是也不返回任何結果,就屬于卡在那里的感覺。這個時候是什么原因呢,就是一開始的第一個Session中的select for update語句把數據鎖定住了。由于這里鎖定的機制是wait的狀態(只要不表示nowait那就是wait),所以第二個Session(也就是卡住的那個sql*plus)中當前這個檢索就處于等待狀態。當第一個session最后commit或者rollback之后,第二個session中的檢索結果就是自動跳出來,并且也把數據鎖定住。不過如果你第二個session中你的檢索語句如下所示。

select * from test where id = 10


也就是沒有for update這種鎖定數據的語句的話,就不會造成阻塞了。另外一種情況,就是當數據庫數據被鎖定的時候,也就是執行剛才for update那條sql以后,我們在另外一個session中執行for update nowait后又是什么樣呢。比如如下的sql語句。 由于這條語句中是制定采用nowait方式來進行檢索,所以當發現數據被別的session鎖定中的時候,就會迅速返回ORA-00054錯誤,內容是資源正忙, 但指定以 NOWAIT 方式獲取資源。所以在程序中我們可以采用nowait方式迅速判斷當前數據是否被鎖定中,如果鎖定中的話,就要采取相應的業務措施進行處理。

select * from test where id = 10 for update nowait


那這里另外一個問題,就是當我們鎖定住數據的時候,我們對數據進行更新和刪除的話會是什么樣呢。比如同樣,我們讓第一個Session鎖定住id=10的那條數據,我們在第二個session中執行如下語句。

update test set value=2 where id = 10


這個時候我們發現update語句就好像select for update語句一樣也停住卡在這里,當你第一個session放開鎖定以后update才能正常運行。當你update運行后,數據又被你update語句鎖定住了,這個時候只要你update后還沒有commit,別的session照樣不能對數據進行鎖定更新等等。

總之,Oracle中的悲觀鎖就是利用Oracle的Connection對數據進行鎖定。在Oracle中,用這種行級鎖帶來的性能損失是很小的,只是要注意程序邏輯,不要給你一不小心搞成死鎖了就好。而且由于數據的及時鎖定,在數據提交時候就不呼出現沖突,可以省去很多惱人的數據沖突處理。缺點就是你必須要始終有一條數據庫連接,就是說在整個鎖定到最后放開鎖的過程中,你的數據庫聯接要始終保持住。與悲觀鎖相對的,我們有了樂觀鎖。樂觀鎖一開始也說了,就是一開始假設不會造成數據沖突,在最后提交的時候再進行數據沖突檢測。在樂觀鎖中,我們有3種

常用的做法來實現。

[1]第一種就是在數據取得的時候把整個數據都copy到應用中,在進行提交的時候比對當前數據庫中的數據和開始的時候更新前取得的數據。當發現兩個數據一模一樣以后,就表示沒有沖突可以提交,否則則是并發沖突,需要去用業務邏輯進行解決。

[2]第二種樂觀鎖的做法就是采用版本戳,這個在Hibernate中得到了使用。采用版本戳的話,首先需要在你有樂觀鎖的數據庫table上建立一個新的column,比如為number型,當你數據每更新一次的時候,版本數就會往上增加1。比如同樣有2個session同樣對某條數據進行操作。兩者都取到當前的數據的版本號為1,當第一個session進行數據更新后,在提交的時候查看到當前數據的版本還為1,和自己一開始取到的版本相同。就正式提交,然后把版本號增加1,這個時候當前數據的版本為2。當第二個session也更新了數據提交的時候,發現數據庫中版本為2,和一開始這個session取到的版本號不一致,就知道別人更新過此條數據,這個時候再進行業務處理,比如整個Transaction都Rollback等等操作。在用版本戳的時候,可以在應用程序側使用版本戳的驗證,也可以在數據庫側采用Trigger(觸發器)來進行驗證。不過數據庫的Trigger的性能開銷還是比較的大,所以能在應用側進行驗證的話還是推薦不用Trigger。

[3]第三種做法和第二種做法有點類似,就是也新增一個Table的Column,不過這次這個column是采用timestamp型,存儲數據最后更新的時間。在Oracle9i以后可以采用新的數據類型,也就是timestamp with time zone類型來做時間戳。這種Timestamp的數據精度在Oracle的時間類型中是最高的,精確到微秒(還沒到納秒的級別),一般來說,加上數據庫處理時間和人的思考動作時間,微秒級別是非常非常夠了,其實只要精確到毫秒甚至秒都應該沒有什么問題。和剛才的版本戳類似,也是在更新提交的時候檢查當前數據庫中數據的時間戳和自己更新前取到的時間戳進行對比,如果一致則OK,否則就是版本沖突。如果不想把代碼寫在程序中或者由于別的原因無法把代碼寫在現有的程序中,也可以把這個時間戳樂觀鎖邏輯寫在Trigger或者存儲過程中。

 


本文出自:億恩科技【www.23lll.com】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    九色成人免费视频_久久一区视频_视频一区国产精品_精品视频在线观看
    国产精品日韩欧美| 日韩午夜激情| 欧美日韩亚洲另类| 欧美丰满少妇xxxbbb| 久久久精品欧美丰满| 新片速递亚洲合集欧美合集| 亚洲天堂av在线免费观看| 一区二区av| 一区二区久久久久久| 99精品国产福利在线观看免费| 久久精品夜色噜噜亚洲a∨ | 久久精品亚洲一区| 欧美在线看片| 欧美在线视频一区二区三区| 欧美一区=区| 欧美一区二区精品久久911| 午夜视黄欧洲亚洲| 欧美伊人久久大香线蕉综合69| 午夜精品一区二区三区在线视| 亚洲欧美日韩国产| 欧美一区二视频| 久久久精品tv| 免费成人网www| 欧美成人午夜免费视在线看片| 你懂的国产精品永久在线| 牛人盗摄一区二区三区视频| 欧美成人免费网| 欧美日韩国产综合视频在线| 欧美午夜视频在线观看| 国产精品大片| 国产私拍一区| 在线观看国产日韩| 日韩视频精品在线| 亚洲一区二区三区免费视频 | 午夜精品影院| 亚洲第一中文字幕| 亚洲精品影视| 亚洲影院高清在线| 久久成人综合网| 欧美成年人视频网站| 欧美日韩亚洲综合一区| 国产精品一区二区久久| 国内免费精品永久在线视频| 亚洲电影自拍| 在线一区二区三区做爰视频网站| 亚洲欧美www| 亚洲级视频在线观看免费1级| 亚洲免费观看高清完整版在线观看| 亚洲手机视频| 久久久99久久精品女同性| 欧美华人在线视频| 国产精品欧美日韩一区| 激情成人综合网| 日韩图片一区| 欧美一级免费视频| 亚洲乱亚洲高清| 性一交一乱一区二区洋洋av| 女人天堂亚洲aⅴ在线观看| 国产精品xxxxx| 伊人激情综合| 亚洲一区二区三区精品视频 | 亚洲欧美国产三级| 久久久亚洲国产天美传媒修理工 | 亚洲国产精品v| 亚洲免费一级电影| 亚洲人成网站色ww在线| 亚洲欧美一区二区三区极速播放 | 亚洲国产老妈| 亚洲欧美日韩国产成人| 亚洲卡通欧美制服中文| 久久成人国产精品| 欧美日韩精品一区| 国产曰批免费观看久久久| 亚洲久色影视| 91久久国产综合久久蜜月精品 | 午夜欧美理论片| 一本一本久久| 美女免费视频一区| 国产欧美日韩三级| aa级大片欧美三级| 亚洲日本欧美天堂| 久久久久**毛片大全| 国产精品久久久久aaaa九色| 亚洲国产综合在线看不卡| 午夜视频精品| 亚洲女同性videos| 欧美精品免费在线观看| 黑人巨大精品欧美一区二区小视频 | 欧美淫片网站| 欧美日韩亚洲系列| 在线欧美日韩国产| 久久精品国产99| 欧美中文字幕在线播放| 国产精品xxxav免费视频| 亚洲片国产一区一级在线观看| 久久国产婷婷国产香蕉| 欧美一区二区免费观在线| 欧美午夜激情视频| 亚洲日本激情| 亚洲人成在线观看网站高清| 久久久国产精品一区二区三区| 国产精品久久久久久久电影| 亚洲精品视频一区二区三区| 亚洲国产精品专区久久| 久久理论片午夜琪琪电影网| 国产精品一级久久久| 一区二区日韩欧美| 亚洲视频福利| 欧美日韩精品一区二区| 亚洲精品日韩一| 日韩一级免费| 欧美精品激情blacked18| 在线欧美日韩国产| 91久久国产精品91久久性色| 美脚丝袜一区二区三区在线观看 | 久久人人爽爽爽人久久久| 国产日韩欧美一区| 西西裸体人体做爰大胆久久久| 午夜伦欧美伦电影理论片| 国产精品a级| 在线视频精品一| 亚洲综合精品四区| 国产精品成人午夜| 亚洲深夜福利视频| 亚洲免费影院| 国产美女精品视频免费观看| 午夜视频一区二区| 久久久91精品国产一区二区三区 | 国产精品国产三级国产aⅴ入口| 日韩小视频在线观看专区| 夜夜嗨av一区二区三区网站四季av| 欧美韩日一区二区| 亚洲美女视频| 亚洲一二三区精品| 国产精品乱人伦中文| 性欧美超级视频| 久久深夜福利| 亚洲国产精品成人一区二区| 亚洲美洲欧洲综合国产一区| 欧美激情一区二区三区| 日韩午夜av电影| 亚洲欧美网站| 韩日视频一区| 亚洲久久成人| 国产精品久久久久久久久果冻传媒| 亚洲一区免费在线观看| 久久精品一级爱片| 在线观看一区欧美| 99精品国产在热久久婷婷| 国产精品国产精品| 欧美在线视频日韩| 欧美国产高清| 亚洲一区二区久久| 久久久午夜视频| 亚洲人久久久| 亚洲影院免费| 狠狠干成人综合网| 亚洲精品社区| 国产精品男女猛烈高潮激情 | 欧美日韩综合视频网址| 亚洲欧美日韩国产中文| 蜜臀a∨国产成人精品| 亚洲三级观看| 久久不射电影网| 亚洲激情在线视频| 亚洲欧美中文日韩在线| 激情综合五月天| 亚洲综合999| 在线观看亚洲精品视频| 亚洲制服丝袜在线| 国内精品国产成人| 一区二区久久久久久| 国产欧美日韩综合精品二区| 亚洲精品久久久久久久久久久久| 欧美视频精品在线| 欧美专区在线观看一区| 欧美日韩a区| 欧美亚洲视频一区二区| 欧美日本一区| 香蕉成人伊视频在线观看| 欧美精品久久一区| 久久福利资源站| 国产精品激情偷乱一区二区∴| 久久精品国产第一区二区三区最新章节| 欧美日韩精品在线| 久久精品72免费观看| 欧美午夜片在线观看| 亚洲国产精品久久久| 国产精品区一区二区三| 亚洲免费观看在线视频| 国产亚洲综合精品| 亚洲一区二区三区精品动漫| 精品av久久707| 香蕉国产精品偷在线观看不卡| 亚洲国产精品久久人人爱蜜臀 | 欧美日韩在线影院| 亚洲国产高潮在线观看| 国产精品在线看| 国产精品99久久99久久久二8| 狠狠色香婷婷久久亚洲精品|