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

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 閱讀(380) 評論(0)  編輯 收藏 引用 所屬分類: Database
<2009年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

常用鏈接

留言簿(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>
            久久久蜜桃精品| 欧美激情一区二区三区全黄 | 久久亚洲一区二区三区四区| 亚洲欧美激情在线视频| 国产亚洲第一区| 久久―日本道色综合久久| 久久激情一区| 亚洲精品乱码久久久久久久久 | 日韩一区二区高清| 欧美视频亚洲视频| 久久精品毛片| 欧美本精品男人aⅴ天堂| 一本色道久久综合精品竹菊| 一区二区日韩欧美| 国产一区二区中文字幕免费看| 久久全球大尺度高清视频| 久久天天躁狠狠躁夜夜av| 99re热精品| 欧美一区二区三区在线视频| 亚洲国产视频直播| 亚洲午夜视频在线观看| 狠狠色狠狠色综合日日五| 亚洲国产精品久久久久婷婷884| 欧美日韩国产综合久久| 久久精品一区中文字幕| 欧美精品色一区二区三区| 欧美一区二区三区免费看| 女同一区二区| 欧美一区日韩一区| 欧美激情精品久久久六区热门 | 黄色欧美成人| 亚洲另类在线视频| 精品白丝av| 亚洲午夜激情网页| 亚洲激情欧美激情| 午夜伦欧美伦电影理论片| 亚洲精品中文在线| 久久精品亚洲精品国产欧美kt∨| 一个色综合av| 蜜桃久久精品乱码一区二区| 久久成人免费电影| 欧美视频免费在线| 亚洲福利在线观看| 精品不卡在线| 午夜影院日韩| 亚洲欧美日韩精品一区二区| 欧美激情二区三区| 欧美韩国在线| 一区二区在线观看视频| 午夜精品久久久久久久99黑人| 亚洲最新在线| 裸体丰满少妇做受久久99精品| 久久福利一区| 国产精品视频男人的天堂| 99精品视频一区| 日韩视频中文字幕| 欧美激情影音先锋| 亚洲第一黄色| 亚洲二区三区四区| 久久永久免费| 欧美激情按摩| 亚洲激情视频在线播放| 久久综合五月| 亚洲成人自拍视频| 91久久在线观看| 美女诱惑一区| 亚洲大胆人体在线| 亚洲国内自拍| 欧美人与禽猛交乱配视频| 亚洲精品国产精品国自产观看浪潮 | 一区二区三区四区国产| 中文一区二区在线观看| 欧美日韩久久| 99国产精品久久久久久久久久| 亚洲性视频网站| 国产精品大片免费观看| 亚洲亚洲精品三区日韩精品在线视频 | 久久久亚洲精品一区二区三区| 老司机精品久久| 亚洲国产综合91精品麻豆| 欧美激情一区二区三区蜜桃视频 | 亚洲在线电影| 久久精品欧洲| 亚洲第一网站| 欧美日韩亚洲综合| 亚洲欧美国内爽妇网| 蜜桃av一区二区三区| 日韩视频中文字幕| 国产精品久久久久一区| 欧美亚洲专区| 亚洲国产福利在线| 亚洲永久在线| 黄色成人在线| 欧美日韩国产综合网| 亚洲男女自偷自拍图片另类| 久久影音先锋| 亚洲一区二区三区精品在线| 国产一区二区三区在线观看网站| 美女主播精品视频一二三四| 夜夜嗨av色综合久久久综合网| 欧美一区二区三区精品| 最新国产乱人伦偷精品免费网站 | 久久xxxx精品视频| 亚洲美女啪啪| 久久亚洲欧美国产精品乐播| 一本久道综合久久精品| 国产精品一二三四| 欧美激情日韩| 久久久久久高潮国产精品视| 99在线精品免费视频九九视| 久久久久久午夜| 亚洲系列中文字幕| 亚洲第一区在线观看| 国产精品一级二级三级| 欧美成人免费网| 久久久久久夜精品精品免费| 一区二区三欧美| 亚洲国产一区二区三区高清| 久久欧美中文字幕| 欧美一区二区| 亚洲特级片在线| 亚洲精品日产精品乱码不卡| 国产午夜一区二区三区| 国产精品国产成人国产三级| 欧美成人精品不卡视频在线观看| 欧美一区二区三区在线观看视频| 99视频在线观看一区三区| 亚洲国产激情| 欧美激情精品久久久久久| 久久av红桃一区二区小说| 亚洲一级网站| 一个色综合av| 99国产精品99久久久久久| 91久久精品一区| 亚洲国产精品一区| 黄色成人在线网站| 精品999久久久| 尤物yw午夜国产精品视频明星| 国产色爱av资源综合区| 国产乱人伦精品一区二区 | 欧美女同视频| 欧美国产精品日韩| 欧美激情影音先锋| 欧美激情女人20p| 欧美精品在线免费观看| 欧美精品亚洲精品| 欧美日韩亚洲一区二区三区在线| 欧美理论电影在线观看| 欧美老女人xx| 国产精品二区影院| 国产精品一区二区久久| 国产亚洲观看| 在线免费观看视频一区| 亚洲黄色影片| 中文一区二区| 欧美亚洲一区二区在线观看| 欧美在线一级va免费观看| 久久久久国产免费免费| 麻豆精品在线观看| 亚洲黄页一区| 一区二区三区视频免费在线观看| 亚洲制服欧美中文字幕中文字幕| 午夜久久资源| 你懂的亚洲视频| 欧美视频一区二区三区四区| 国产精品日韩在线| 加勒比av一区二区| 亚洲免费精品| 欧美一区二区三区婷婷月色 | 日韩一级免费观看| 午夜精品国产精品大乳美女| 久久精品国产精品亚洲| 欧美国产在线电影| 国产精品视频免费观看| 亚洲第一在线视频| 亚洲一区二区三区中文字幕在线| 欧美在线亚洲| 最新亚洲激情| 欧美一区二区三区精品| 欧美激情精品久久久久| 国产情人综合久久777777| 亚洲国产日韩欧美| 午夜精品国产| 亚洲激情成人在线| 欧美亚洲一区二区三区| 欧美日本韩国| 在线日韩电影| 欧美在线免费观看视频| 亚洲人成艺术| 久久天天躁狠狠躁夜夜av| 国产精品久久久久久超碰| 亚洲福利在线观看| 久久精品盗摄| 在线中文字幕日韩| 欧美成黄导航| 在线观看视频一区| 欧美一区观看| 亚洲深夜福利视频| 欧美日本高清一区| 亚洲区免费影片|