青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0
INFORMIX使用鎖技術解決在多用戶訪問數據庫情況下,對同一對象訪問的并發控制問題。INFORMIX支持復雜的、可伸縮性的鎖技術。

鎖的類型

INFORMIX有三種不同類型的鎖。它們在不同的情況下使用。

1. SHARED鎖

    SHARED鎖只保留對象的可讀性。當鎖存在時,對象不能改變。多個程序可對同個對象加SHARED鎖。

2. EXCLUSIVE鎖

    只能使單個程序使用。在程序要改變對象時使用。當其他鎖存在時,EXCLUSIVE鎖不能使用。當使用了EXCLUSIVE 鎖后,其他鎖不能用于同一對象。

3. PROMOTABLE鎖

    實現更新的目的。PROMOTABLE鎖可以放在已經有SHARED鎖的記錄,但不能放在已經有PROMOTABLE鎖和EXCLUSIVE鎖的地方。當記錄上無其他鎖(含SHARED 鎖)情況下,這時在程序準備改變鎖的記錄時,PROMOTABLE鎖可以提升為EXCLUSIVE鎖。如果在已有SHARED鎖的記錄上設置了PROMOTABLE鎖,在PROMOTABLE鎖可以提升到EXCLUSIVE鎖之前需要刪除SHARED 鎖。PROMOTABLE鎖只能在INFORMIX Universal Server中支持。

鎖的范圍

    INFORMIX對于數據鎖定提供了三種不同的方式,范圍由大到小分別是數據庫、表、記錄級鎖。使用的時機要看應
用狀況而定。

1. 數據庫級鎖

    你可以用CONNECT, DATABASE, 或 CREATE DATABASE語句打開數據庫。打開數據庫的操作就在數據庫上設置了SHARED鎖。只要程序打開一個數據庫,SHARED鎖就會阻止其他程序刪除數據庫或在數據庫上設置EXCLUSIVE鎖。你可以用語句DATABASE database name EXCLUSIVE鎖定整個數據庫。若此時其他用戶正在使用該數據庫,該操作將返回錯誤。一旦設置了EXCLUSIVE鎖,其他程序就不能打開數據庫,因為打開時要放置一個SHARED鎖。只有數據庫關閉時,數據庫鎖才釋放。你可以用DISCONNECT或CLOSE DATABASE顯示地處理,也可以運行其他的DATABASE語句隱含的處理。一般數據庫級EXCLUSIVE鎖是獨占數據庫資源,防止其他程序訪問數據庫。它使得程序非常簡單,不會產生并發效果。常用在非高峰時期要改變大量數據時如數據庫備份過程。

2. 表級鎖

    INFORMIX提供兩種模式表級鎖:EXCLUSIVE MODE 和SHARE MODE。你可以鎖整個表。在某些情況下,這個操作是自動進行。當INFORMIX處理下列語句時,一般鎖整個的表:ALTER INDEX 、ALTER TABLE 、CREATE INDEX、DROP INDEX 、RENAME COLUMN、RENAME TABLE 。該語句結束或事務結束會釋放該鎖。在某些查詢語句中,INFORMIX也自動鎖整個表。你可以用LOCK TABLE語句顯示地鎖整個表。該語句允許你對整個表設置EXCLUSIVE鎖或SHARED鎖。當你程序從表中讀取數據時,SHARED鎖防止表中數據更新。INFORMIX Universal Server 通過設置隔離級別實現更大程度并發數據保護。 

    表級EXCLUSIVE鎖防止對同個表的并發使用。因此,如果其他許多程序要使用該表時,系統性能會受到嚴重影響。類似數據庫級EXCLUSIVE鎖,表級EXCLUSIVE鎖常用在非高峰時期要改變大量數據時。例如,有些應用在高峰期間并不更新表,它們可以在非高峰期間定期以批處理方式更新。

    通過UNLOCK TABLE table name 解除鎖。當存在事務時,事務結束時解除鎖。

3. 記錄級、頁級、鍵字級鎖

    表的一個記錄是可設置鎖的最小對象。一個程序可以鎖一個記錄或記錄的集合,同時其他程序可以操作同一個表的其他記錄。Universal Server 以磁盤頁面(disk pages)為單位存儲數據。一個磁盤頁面包含一個或多個記錄。在有些情況下,頁級鎖比單個鎖更好些。其他數據庫服務器可能不存在頁級、鍵字級鎖。

    在Universal Server上,當你創建表時,你可以選擇使用記錄級鎖或頁級鎖。其他的數據庫服務器不提供這種選擇。頁級、記錄級鎖有相同的效果。當Universal Server需要鎖一個記錄時,根據表創建時的鎖模式,鎖這個記錄或記錄所在的頁面。在一定情況下,數據庫服務器需要鎖一個不存在的記錄。它的效果相當于在記錄將要存在的地方放一個
鎖。當表使用記錄鎖時,對假想的記錄使用鍵字鎖。當表使用頁級鎖時,含有或可能含有鍵字的索引頁將被設置鍵級鎖。

鎖的時期

    程序控制數據庫級鎖的時期。數據庫關閉時,數據庫鎖級也就釋放。表級、記錄級、索引級鎖的時期依賴于使用的SQL語句以及是否使用事務。如果數據庫沒有使用事務,也就是說,事務日志不存在并且你沒有使用COMMIT WORK語句,當運行UNLOCK TABLE語句時,表級鎖就釋放。當使用了事務時,事務結束,表級、記錄級、索引級鎖都釋放。
 
修改時鎖的處理

    當數據庫服務器通過一個更新游標取一條記錄時,它在該記錄上設置一個PROMOTABLE鎖。如果這個動作成功,數據庫服務器知道其他程序不能改變此記錄。因為PROMOTABLE鎖不是獨占的,其他程序能夠繼續讀這條記錄。由于在取此記錄的程序執行UPDATE、DELETE語句或簡單地取下一條記錄之前,它可能花一些時間。這樣就提高了性能。當它改變一個記錄時,數據庫服務器在這條記錄上設置一個EXCLUSIVE鎖。如果它已經有一個PROMOTABLE鎖,它將鎖改為EXCLUSIVE狀態。

    EXCLUSIVE鎖的時期依賴于是否使用事務。如果沒有使用事務,被修改的記錄寫到磁盤上就會釋放該鎖。當使用了事務時, 鎖就會保持到事務的結束。這個動作防止其他程序使用可能回滾到原來狀態的記錄。

    當使用了事務時,只要刪除記錄鍵級鎖就會設置。使用鍵級鎖解決下列錯誤:程序A刪除一個記錄,程序B插入有同樣鍵的記錄。程序A回滾事務,使數據庫服務器恢復了刪除的記錄,這時程序B插入的記錄怎么辦?通過鎖索引,數據庫服務器等到程序A提交事務時才插入記錄。

    由于 Universal Server數據庫服務器管理自己的鎖,所以它能提供不同類型的鎖。其他的數據庫服務器是通過操作系統的特性實現鎖,所以不能提供多種選擇。有些操作系統通過操作系統服務方式向外提供鎖函數。在這些系統,數據庫支持SET LOCK MODE語句。而有些操作系統不支持內核級的特性,數據庫這時通過在數據庫目錄下產生小文件實現鎖。這些文件帶有.lok后綴。如果你的程序使用單個SELECT語句或沒有用FOR UPDATE聲明的游標提取一個記錄,此記錄不管是否被一個未完成的交易上鎖會馬上被提取。這樣能產生最好的性能。當你使用FOR UPDATE聲明的游標時,它在提取前將當前記錄上鎖。如果當前記錄已經有鎖,隨作選擇模式的不同,程序會等待或返回錯誤。當取下一個記錄時,數據庫看當前記錄是否更新(使用帶WHERE CURRENT OF 的UPDATE)


鎖的模式

鎖的模式決定程序遇到被鎖的數據會產生怎樣的結果。當程序要提取或修改一個上鎖的記錄時,會有下面幾種情況:

1、 數據庫馬上通過SQLCODE變量或SQLSTATE結構給程序返回一個錯誤代碼。

2、 在數據解鎖前,數據庫將程序掛起。

3、數據庫將程序掛起一段時間。如果鎖還未解,數據庫給程序返回一個錯誤代碼。


你可以通過SET LOCK MODE模式選擇以上結果。

如果你喜歡程序等待(對大多數程序而言這是最好的選擇),運行下列語句:SET LOCK MODE TO WAIT。

    當設置了鎖模式后,程序常忽視其他并發程序的存在性。如果程序需要訪問其他程序已上鎖的記錄時,它等待別的程序解鎖,然后繼續。延遲的時間常不可預測。

    等待解鎖不利的一面就是可能會等待很長時間。如果不能接受很長延遲,程序可以運行下列語句:SET LOCK MODE TONOT WAIT選擇不等待。當程序需要一個鎖記錄時,它馬上返回一個錯誤代碼,且當前的SQL語句終止。這時,程序必須回滾當前的交易再試一次。程序開始時,數據庫初始設置為不等待。

    當你使用UNIVERSAL SERVER時,你有另外的選擇。你可以讓數據庫設置等待時間的上限。你可用下列語句:SETLOCK MODE TO WAIT 18讓數據庫有18秒等待上限。若期間鎖還沒有解開,將返回錯誤代碼。

    在每個程序都選擇了鎖等待模式情況下,有可能出現死鎖。死鎖是程序之間相互阻塞,每個程序在其他程序要訪問的對象上設置了鎖。UNIVERSAL SERVER在單個網絡服務器情況下會馬上檢測到死鎖。如果程序選擇了鎖等待模式,通過給程序返回錯誤代碼,你就知道你遇到了死鎖。而在多個數據庫服務器的情況下,UNIVERSAL SERVER不能馬上檢測到。每個數據庫服務器都設置鎖等待的上限。如果超時,數據庫服務器就認為發生了死鎖且返回相關的錯誤代碼。數據庫管理員可以設置和修改等待時間的上限。
轉自:
http://blog.chinaunix.net/u/14063/showart.php?id=114859
posted on 2009-11-15 23:22 chatler 閱讀(376) 評論(0)  編輯 收藏 引用 所屬分類: Database
<2025年10月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产免费一区二区三区香蕉精| 久久av资源网站| 久久人人爽人人爽| 午夜久久影院| 国产日韩一区二区三区在线| 午夜精品国产更新| 亚洲综合日韩在线| 国产综合久久| 免费看成人av| 欧美成人精品h版在线观看| 亚洲精品久久久蜜桃| 亚洲观看高清完整版在线观看| 久久嫩草精品久久久久| 亚洲精品小视频| 日韩午夜三级在线| 国产伦精品一区二区三区在线观看| 欧美一区二区三区电影在线观看| 亚洲午夜av电影| 国内自拍一区| 亚洲电影免费观看高清| 欧美日韩亚洲国产精品| 亚洲欧美制服另类日韩| 久久精品亚洲乱码伦伦中文| 最新日韩在线视频| 亚洲免费av观看| 国产精品亚洲精品| 欧美成人一区二免费视频软件| 欧美日韩国产在线观看| 欧美中文在线免费| 欧美久久一级| 久久精品91久久香蕉加勒比 | 嫩草国产精品入口| 欧美成人一区二区三区在线观看 | …久久精品99久久香蕉国产| 日韩亚洲欧美成人| 激情综合自拍| 亚洲剧情一区二区| 一区在线电影| 亚洲专区一二三| 亚洲精品在线一区二区| 欧美伊人影院| 亚洲欧美电影院| 欧美成人综合| 久久亚洲精选| 国产美女精品视频| 99亚洲精品| 日韩午夜av电影| 久久久久久电影| 欧美一区二区精品| 欧美高清在线视频| 欧美一级免费视频| 欧美日韩国产色综合一二三四| 久久久欧美一区二区| 欧美激情麻豆| 欧美电影在线观看完整版| 国产偷国产偷亚洲高清97cao| 一区二区三区精品视频| 99精品国产在热久久下载| 美女主播视频一区| 亚洲电影天堂av| 久久久久国产一区二区三区| 欧美中文字幕不卡| 国产精品爽爽爽| 99视频超级精品| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 欧美日韩视频一区二区三区| 亚洲高清视频的网址| 在线欧美小视频| 久久久久久欧美| 快she精品国产999| 尤妮丝一区二区裸体视频| 欧美一区二区三区久久精品茉莉花 | 国产精品一区二区在线观看| 99视频精品免费观看| 亚洲欧美制服另类日韩| 国产精品午夜在线观看| 亚洲欧美电影院| 欧美在线观看视频| 欧美性大战xxxxx久久久| 一区二区免费在线视频| 亚洲综合日韩| 国产农村妇女毛片精品久久麻豆 | 亚洲成人自拍视频| 亚洲精品美女| 欧美三级电影大全| 一区二区三区四区精品| 欧美一区二区性| 国产亚洲一区二区三区在线观看 | 欧美顶级艳妇交换群宴| 一区二区在线观看视频| 欧美激情精品久久久久久变态| 亚洲三级视频在线观看| 小处雏高清一区二区三区 | 欧美日韩国产综合视频在线观看| 99精品热6080yy久久| 小黄鸭精品密入口导航| 在线观看一区| 欧美视频网址| 久久久av毛片精品| 亚洲欧洲一区二区在线观看| 亚洲男同1069视频| 国产一区二区三区四区老人| 欧美日韩国产123区| 亚洲欧美在线网| 亚洲国产aⅴ天堂久久| 午夜视频一区二区| 亚洲成人在线观看视频| 欧美丝袜一区二区三区| 久久久水蜜桃av免费网站| 亚洲精品免费在线| 久久一区免费| 午夜精品福利电影| 亚洲激情在线激情| 国产午夜精品美女毛片视频| 欧美交受高潮1| 久久久久国产精品人| 在线中文字幕日韩| 亚洲国产黄色片| 久久久久久夜| 一区免费在线| 另类图片国产| 久久www免费人成看片高清| 在线观看成人av| 国产精品久久久久久久久久久久久久| 久久久久综合| 亚洲精品一区二区三| 9l国产精品久久久久麻豆| 久久成人精品| 一本色道婷婷久久欧美| 最新日韩在线视频| 黑人巨大精品欧美一区二区| 国产精品久久久久久亚洲调教| 欧美国产专区| 久久综合狠狠综合久久综青草| 亚洲男人影院| 亚洲尤物在线| 一区二区日本视频| 亚洲精品中文在线| 亚洲欧洲精品一区二区三区不卡| 免费国产一区二区| 久热精品视频在线观看| 久久精品国产综合| 久久精品视频免费播放| 性色av香蕉一区二区| 午夜久久电影网| 午夜精品视频在线观看| 亚洲欧美日韩中文播放| 亚洲一区二区av电影| 亚洲一区日韩在线| 午夜精品国产| 久久国产精品99精品国产| 国产午夜精品一区二区三区欧美 | 性欧美videos另类喷潮| 亚洲视屏在线播放| 亚洲综合精品自拍| 午夜欧美不卡精品aaaaa| 亚洲欧洲av一区二区| 亚洲欧美日本日韩| 欧美在线视频全部完| 午夜精品久久久久久久男人的天堂| 亚洲欧美日韩人成在线播放| 欧美一区二区视频网站| 久久久精品动漫| 欧美激情一区二区| 国产精品视频精品视频| 国语精品中文字幕| 亚洲狼人综合| 欧美在线一区二区三区| 欧美α欧美αv大片| 亚洲精品社区| 欧美亚洲视频在线看网址| 玖玖玖国产精品| 欧美色123| 狠狠色综合一区二区| 一本色道久久综合精品竹菊| 欧美在线黄色| 欧美激情女人20p| 亚洲在线播放电影| 欧美成人免费va影院高清| 国产精品区一区二区三区| 亚洲高清视频中文字幕| 亚洲综合清纯丝袜自拍| 亚洲电影免费观看高清完整版在线| 亚洲九九精品| 亚洲精品日韩在线观看| 国产一区二区中文| 欧美日韩视频在线| 欧美日韩一区二区在线| 欧美先锋影音| 欧美日韩一区二区三区在线观看免 | 亚洲国产cao| 亚洲欧美国产日韩中文字幕| 亚洲欧美日本精品| 久久先锋资源| 国产亚洲一区二区在线观看| 久久综合伊人77777蜜臀| 亚洲专区一二三| 亚洲精品乱码久久久久久| 亚洲国产欧美一区二区三区久久 | 亚洲人成高清|