資料庫系統(tǒng)理論與實(shí)務(wù)_第1頁
已閱讀1頁,還剩57頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、1,,Ch14.交易處理 交易(Transaction)概念介紹多人系統(tǒng)下的交易的並行控制錯(cuò)誤與例外處理機(jī)制Ch15.資料庫的備份與還原資料庫的備份/還原、卸離/附加介紹資料的匯出與匯入Ch16.SQL Server登入與系統(tǒng)安全SQL Server的登入驗(yàn)證伺服器角色與資料庫角色存取權(quán)限的策略制定,2,交易處理(Transaction Processing),第十四章,3,Chapter 14 Outline,1

2、4-1 交易概念介紹 14-2 錯(cuò)誤回復(fù) 14-3 交易的並行控制 14-4 SQL Server中交易與記錄檔 14-5 與交易有關(guān)的SQL敘述 14-6 建立一交易 14-7 SQL Server 的3種交易類型 14-8 巢狀式交易 14-9 分散式交易 14-10選擇交易隔離層級 14-11鎖定與死結(jié) 14-12本章總結(jié),4,14-1 交易概念介紹,在資料庫系統(tǒng)中,交易(Transaction)概念提供了

3、一個(gè)資料處理的邏輯單元(Logic Unit) 。在該邏輯單元中如果全部執(zhí)行成功,則會確定交易期間所修改的所有資料正式成為資料庫的內(nèi)容;如果有發(fā)生錯(cuò)誤,則必須取消或回復(fù)該交易期間內(nèi)所有的資料修改。 資料庫系統(tǒng)是一個(gè)交易處理系統(tǒng)(Transaction Processing System),它容許交易同步的被執(zhí)行。,5,14-1 交易概念介紹,多使用者系統(tǒng)(Multiuser System)現(xiàn)今多數(shù)DBMS為多使用者系統(tǒng),即同時(shí)容

4、許一個(gè)以上使用者存取資料庫。這是因?yàn)镈BMS安裝在多元程式(multiprogramming)的作業(yè)系統(tǒng)上,這些作業(yè)系統(tǒng)可以同時(shí)存取執(zhí)行一個(gè)以上的處理程序以交錯(cuò)(interleaved)方式分享CPU的使用權(quán)。,6,14-1 交易概念介紹,如下圖所示,有兩個(gè)處理程序Pi和Pj以交錯(cuò)方式被CPU執(zhí)行。在時(shí)間t1,Pi被CPU執(zhí)行。當(dāng)Pi需要資料庫資料,而這些資料不在主記載體時(shí),DBMS必須呼叫作業(yè)系統(tǒng),處理此I/O要求。,7,14-1 交

5、易概念介紹,這時(shí)CPU會中斷Pi的執(zhí)行,再呼叫檔案系統(tǒng)及磁碟管理系統(tǒng)的服務(wù)將資料讀取到主記載體。在此等待的時(shí)間中,為了提高CPU之使用率以及系統(tǒng)整體效能(throughput),CPU會執(zhí)行其他處理程序,在本例中Pj會被CPU的排班程式(scheduler)選出而被執(zhí)行,如上頁圖之時(shí)間t2所示。假如當(dāng)Pi之I/O完成後(時(shí)間t3),經(jīng)過排班程式的選擇,Pi會重新拿到CPU的使用權(quán)。處理程序Pi和Pj以交錯(cuò)方式執(zhí)行其他部份,直到結(jié)束為止

6、。當(dāng)然,一個(gè)處理程序的CPU使用時(shí)間片斷(time slice)用完也會發(fā)生被置換(swap)的情況。,8,14-1 交易概念介紹,為何交易會與多使用者系統(tǒng)有關(guān)係,因?yàn)榇蠖鄶?shù)的資料庫理論是在交錯(cuò)同步(Interleaved Concurrency)的假設(shè)下發(fā)展出來的。由於系統(tǒng)在同一時(shí)間可能會執(zhí)行多的process,因此如何保證資料讀取、寫入的正確性就是交易探討的重要課題。,9,14-1 交易概念介紹,交易的特性(Properties o

7、f Transaction)單元性(Atomicity)一個(gè)交易是一個(gè)單元(Atomic)的處理。如果是正常情況,則整個(gè)交易應(yīng)完整的被執(zhí)行。否則,發(fā)生任一錯(cuò)誤情況時(shí),則將交易所做的資料更新復(fù)原到交易開始前狀況(undo)。因此,單元性也稱之為不可部份完成性。 一致性(Consistency ) 一個(gè)完整的交易能使資料庫從一個(gè)一致性狀態(tài)(consistent state)轉(zhuǎn)換到另一個(gè)一致性狀態(tài)。所謂一致性狀態(tài)是指資料庫的資料滿足資

8、料庫綱要所定義的所有限制,例如整合限制條件。,10,14-1 交易概念介紹,隔離性(Isolation)一個(gè)執(zhí)行中的交易不應(yīng)被其他同步執(zhí)行中的交易所影響,即交易間應(yīng)具有隔離機(jī)制。 耐久性(Durability)一個(gè)交易成功的執(zhí)行「認(rèn)可」(commit)命令後,它對資料庫所作的任何資料更新處理,均反應(yīng)在資料庫中。這些更新動(dòng)作不會受「認(rèn)可」後的任何錯(cuò)誤所影響。,11,14-1 交易概念介紹,交易管理在DBMS是由錯(cuò)誤回復(fù)(Failur

9、e Recovery)和並行控制(Concurrency Control)兩個(gè)主要機(jī)制來達(dá)成 。而交易管理的主要目的是要維持資料庫中資料的一致性(Consistency)和正確性(Correctness)。 錯(cuò)誤回復(fù)機(jī)制是維持交易處理的「單元性」和「耐久性」 並行控制機(jī)制是在維持「隔離性」和「一致性」,12,14-2 錯(cuò)誤回復(fù),當(dāng)一個(gè)交易提交到DBMS要被執(zhí)行時(shí),DBMS的責(zé)任是要管理此交易順利的執(zhí)行,包括下列的情況: 當(dāng)交易成功

10、的執(zhí)行「認(rèn)可」(Commit)後,此交易對資料庫所作的資料更新需反應(yīng)到資料庫中。 在交易執(zhí)行當(dāng)中不會被其他交易影響。 當(dāng)錯(cuò)誤發(fā)生時(shí),交易的操作不會對資料庫產(chǎn)生影響。,13,14-2 錯(cuò)誤回復(fù),錯(cuò)誤種類(Types of Failures):一般可分為3大類,交易錯(cuò)誤、系統(tǒng)錯(cuò)誤以及儲存媒體錯(cuò)誤交易錯(cuò)誤(Transaction Failures)邏輯錯(cuò)誤(Logical Error) 資料錯(cuò)誤(Data Error) 同步控制強(qiáng)

11、制錯(cuò)誤(Concurrency Control Enforcement Error) 系統(tǒng)錯(cuò)誤(System Failure)電腦錯(cuò)誤(Computer Failures) 天災(zāi)(Catastrophes),14,14-2 錯(cuò)誤回復(fù),儲存媒體錯(cuò)誤(Storage Media Failures)主要是指磁碟錯(cuò)誤。當(dāng)交易正在讀寫資料庫資料時(shí),發(fā)生磁碟錯(cuò)誤,以致磁碟中資料可能遺失。針對這種錯(cuò)誤可使用RAID(Redundant Arr

12、ay of Inexpensive Disk)硬體提高資料安全性。,15,14-2 錯(cuò)誤回復(fù),錯(cuò)誤回復(fù)程序(Procedure of Failure Recovery)這個(gè)程序DBMS能自動(dòng)完成而不需任何人工作業(yè)。在說明回復(fù)程序前,我們必須先介紹「檢查點(diǎn)」(checkpoint)事件?!笝z查點(diǎn)」是一個(gè)系統(tǒng)設(shè)定的時(shí)間(例如:5分鐘、10分鐘),DBMS每隔「檢查點(diǎn)」所設(shè)定的時(shí)間會處理以下的動(dòng)作:將主記憶體內(nèi)所有日誌(Log)紀(jì)錄存回磁

13、碟中。 將緩衝區(qū)內(nèi)已認(rèn)可(Commit)交易之資料回存到磁碟。 在日誌中存入檢查點(diǎn)紀(jì)錄。,16,14-2 錯(cuò)誤回復(fù),檢查點(diǎn)記錄的主要功能是幫助回復(fù)程序作Redo和Undo工作,所以包含了系統(tǒng)重啟之後必須處理的資訊。 Redo:當(dāng)系統(tǒng)發(fā)生錯(cuò)誤前,交易已作「認(rèn)可」(Commit)動(dòng)作,但資料尚未寫到磁碟上,根據(jù)「一致性原則」,從最後一個(gè)「檢查點(diǎn)」到「認(rèn)可」的操作,需要Redo,或稱之為向前恢復(fù)(Roll Forward)。 Undo

14、:當(dāng)錯(cuò)誤發(fā)生前,交易還未做「認(rèn)可」動(dòng)作,此時(shí)需要強(qiáng)制中斷該交易而作Undo的動(dòng)作,也稱之為Rollback。,17,14-3 交易的並行控制,在一個(gè)多元程式(Multiprogramming)或多工(Multi-tasking)的資料庫系統(tǒng)中,必須提供「並行控制」(Concurrency Control)機(jī)制,否則會發(fā)生下列問題: 遺失更新問題(Lost Update Program) 暫時(shí)更新問題(Temporary Update

15、 Problem) 不可重複讀取(Nonrepeatable Read) 幽靈讀取(Phantom Read),18,14-3 交易的並行控制,遺失更新問題(Lost Update Program):兩個(gè)交易交錯(cuò)地讀取了共用資料,並且作更新的操作,使得前一個(gè)交易的資料更新作業(yè)遺失了 。,交易T1先讀取資料項(xiàng)目X,然後對X作更新處理(X = X + 100)。接著交易T2也讀取X且作X = X - 500的處理。交易T1將X寫入資

16、料庫中。交易T2也將X更新至資料庫。最後交易T1和T2分別執(zhí)行「認(rèn)可」(Commit)處理。在此情況下,交易T1對資料項(xiàng)目X的更新被交易T2所影響而遺失了。,19,14-3 交易的並行控制,暫時(shí)更新問題(Temporary Update Problem) 當(dāng)交易T1更新了某資料項(xiàng)目X,但在某原因之下這個(gè)交易被迫放棄(Abort)。如果資料項(xiàng)目X也被另一個(gè)交易T2讀取,這時(shí)候交易T2也必須連帶的將X回存成舊有的資料值(即T2也被Ab

17、ort)。,20,14-3 交易的並行控制,暫時(shí)更新問題如圖所示交易T1更新了資料X但在正常結(jié)束前發(fā)生了錯(cuò)誤,使得X必須回復(fù)成舊的資料值。所以交易T2讀取了資料X的「暫時(shí)值」(Temporary value)。這個(gè)被T2讀取的資料也被稱為「髒資料」(Dirty data),因此該問題也被稱為「髒讀取問題」(Dirty Read Problem)。,21,14-3 交易的並行控制,不可重複讀取(Nonrepeatable Read):

18、也稱之為不一致分析 (Inconsistent Analysis),該情況發(fā)生在一交易讀取同一資料數(shù)次以上。,例如:交易1在不同時(shí)間點(diǎn)讀取同一筆資料一次以上,而在其中任兩次讀取之間,有另一個(gè)交易2改變了該筆資料。此時(shí)則因?yàn)樵撡Y料錄的內(nèi)容被改變了,所以會造成交易1讀取了不同內(nèi)容的同一筆資料,22,14-3 交易的並行控制,幽靈讀取(Phantom Read ):發(fā)生在兩個(gè)交易中都對資料表作INSERT或DELETE動(dòng)作時(shí)所發(fā)生。 例如:

19、當(dāng)交易1讀取一資料表,而交易2在交易1結(jié)束之前新增了一筆資料到該資料表中,則該筆新增資料對交易1而言有如幽靈(Phantom),因?yàn)榕c第一次所讀到的資料不相同。反之,當(dāng)交易1讀取一資料表時(shí),而交易2卻刪除一些資料錄,結(jié)果就造成交易1中存在一些不屬於該資料表的幽靈資料錄。,23,14-3 交易的並行控制,並行控制的方法可分為二類:悲觀並行控制(Pessimistic)與樂觀並行控制(Optimistic) 悲觀並行控制:使用者在執(zhí)行某個(gè)

20、動(dòng)作而鎖定某些資源之後,其他使用者就不能執(zhí)行會與該鎖定衝突的動(dòng)作,直到擁有者解除鎖定為止。主要是用在高度爭用資源的環(huán)境中,以鎖定方式來保護(hù)資源的成本,會低於發(fā)生並行衝突時(shí)回復(fù)交易的成本。 樂觀並行控制:在該類型並行控制中,使用者在讀取資料時(shí),並不會將資料鎖定。主要是用在低度爭用資源的環(huán)境中,偶爾回復(fù)交易的成本會優(yōu)於讀取時(shí)鎖定資料的成本。,24,14-4 SQL Server中交易與記錄檔,交易是一組具有邏輯關(guān)聯(lián)性動(dòng)作的集合,所有的動(dòng)

21、作必須全部完成,不然就是必須一件都未發(fā)生,不能夠處於部分完成的狀態(tài),一交易是不可分割的。例如:將遊戲點(diǎn)數(shù)由A帳號轉(zhuǎn)移至B帳號即是一個(gè)交易應(yīng)用,該交易包含了下面兩個(gè)動(dòng)作:因轉(zhuǎn)出動(dòng)作而修改A帳號資料 因轉(zhuǎn)入動(dòng)作而修改B帳號資料,25,14-4 SQL Server中交易與記錄檔,如果系統(tǒng)已經(jīng)完成了由A帳號轉(zhuǎn)出的動(dòng)作,而此時(shí)發(fā)生了系統(tǒng)當(dāng)機(jī),當(dāng)系統(tǒng)重新開機(jī)後,A帳號客戶就會白白的損失一筆遊戲點(diǎn)數(shù),因?yàn)樯形崔D(zhuǎn)到B帳號,這樣的系統(tǒng)就不太會有人敢

22、使用了。因此,對於一個(gè)交易內(nèi)所有動(dòng)作的處理,必須是所有動(dòng)作全部完成,否則就必須是所有動(dòng)作全都沒有發(fā)生,這就是交易最基本的精神。,26,14-4 SQL Server中交易與記錄檔,交易的三個(gè)相關(guān)名詞-- ROLLBACK、SAVEPOINT以及COMMIT ROLLBACK:當(dāng)系統(tǒng)發(fā)生錯(cuò)誤的時(shí)候,將部分完成交易解除作用,ROLLBACK可以將一交易復(fù)原至一SAVEPOINT或是交易開始時(shí)的狀態(tài)。 SAVEPOINT:一個(gè)位置定義器,

23、可以於一交易內(nèi)定義SAVEPOINT,當(dāng)系統(tǒng)發(fā)生錯(cuò)誤時(shí)將交易復(fù)原至一SAVEPOINT。 COMMIT:是存檔的動(dòng)作,它會將一交易內(nèi)所有對資料庫的修訂儲存至磁碟上。COMMIT可以保証所有的改變將成為資料庫的永久一部分,而且會釋放交易所使用的資源。,27,14-5 與交易有關(guān)的SQL敘述,BEGIN TRANSACTION COMMIT TRANSACTION COMMIT WORK SAVE TRANSACTION ROLL

24、BACK TRANSACTION ROLLBACK WORK,28,14-5 與交易有關(guān)的SQL敘述,BEGIN TRANSACTION敘述語法結(jié)構(gòu): BEGIN TRAN[SACTION] [transaction_name | @tran_name_variable] 功能:標(biāo)示一使用者定義交易的起始點(diǎn)引數(shù): transaction_name:為交易的指定名稱,transaction_name必須遵循識別字的命名

25、規(guī)則,有效位數(shù)為32個(gè)文字。@tran_name_variable:為一地區(qū)性變數(shù),包含一交易的名稱,必須為文字資料型態(tài)。,29,14-5 與交易有關(guān)的SQL敘述,COMMIT TRANSACTION敘述語法結(jié)構(gòu): COMMIT TRAN[SACTION] [transaction_name | @tran_name_variable]功能:標(biāo)示一交易的終止點(diǎn),表示一交易已成功的被執(zhí)行了。引數(shù):transaction_na

26、me:為前面BEGIN TRANSACTION敘述所指定的交易名稱,但SQL Server會忽略該transaction_name。tran_name_variable:為地區(qū)性一變數(shù),包含一交易的名稱,必須為文字資料型態(tài)。,30,14-5 與交易有關(guān)的SQL敘述,COMMIT WORK敘述語法結(jié)構(gòu):COMMIT [WORK]功能:與COMMIT TRANSACTION相同,但是不能接受一使用者定義的交易名稱。COMMIT

27、 [WORK],31,14-5 與交易有關(guān)的SQL敘述,SAVE TRANSACTION敘述語法結(jié)構(gòu):SAVE TRAN[SACTION] [savepoint_name | @savepoint_variable]功能:在一交易內(nèi)設(shè)定一SAVEPOINT引數(shù):savepoint_name:為一SAVEPOINT的指定名稱@savepoint_variable:為一變數(shù),包含一SAVEPOINT的名稱,必須為文字資料型

28、態(tài)。,32,14-5 與交易有關(guān)的SQL敘述,ROLLBACK TRANSACTION敘述語法結(jié)構(gòu):ROLLBACK TRAN[SACTION] [transaction_name | @tran_name_variable | savepoint_name | @savepoint_variable]功能:將一交易ROLLBACK至交易的起始點(diǎn)或交易內(nèi)的SAVEPOINT引數(shù):transaction_name:為一於BEGIN

29、 TRANSACTION敘述指定的交易名稱@tran_name_variable:為一地區(qū)性變數(shù),包含一交易的名稱,必須為文字資料型態(tài)。savepoint_name:為一SAVEPOINT的指定名稱@savepoint_variable:為一地區(qū)性變數(shù),包含一SAVEPOINT的名稱,必須為文字資料型態(tài)。,33,14-6 建立一交易,如何使用BEGIN TRANSACTION、COMMIT、SAVEPOINT以及ROLLBACK敘

30、述,撰寫一個(gè)交易呢?一個(gè)交易的結(jié)構(gòu)大致如下:BEGIN TRANSACTIONstatement1statement2. . . . .statementNIF (success) COMMIT TRANSACTIONELSE ROLLBACK TRANSACTIONENDIFBEGIN TRANSACTION標(biāo)示著一個(gè)交易的開始,然後開始一系列的SQL操作敘述,最後檢查

31、是否所有的資料修訂都已成功的被完成,是則執(zhí)行COMMIT敘述將資料寫入磁碟,否則執(zhí)行ROLLBACK敘述將資料回復(fù)至交易發(fā)生前的狀態(tài)。,34,14-6 建立一交易,範(fàn)例14-6.1:請新增一筆訂單,訂單號碼為200,訂貨日期為2007-04-01,經(jīng)銷商號碼為1019。該訂單包含兩個(gè)單項(xiàng),第一單項(xiàng)產(chǎn)品號碼為1,供應(yīng)商代碼為HSC,數(shù)量為2;第二單項(xiàng)產(chǎn)品號碼為2,供應(yīng)商代碼為HFT,數(shù)量為6。很明顯的必須將3個(gè)insert(一筆訂單資料

32、,兩筆訂單細(xì)項(xiàng)資料)包裝在一個(gè)交易中,因?yàn)樾略隽擞唵蔚菦]有新增細(xì)項(xiàng)資料就不正確。但是在新增資料的過程中要一一檢查是否正確才能COMMIT 由於必須依依檢查,因此決定採用try …catch機(jī)制,35,14-6 建立一交易,SET IDENTITY_INSERT orders ON;BEGIN TRAN --開始交易begin try --啟動(dòng)例外處理機(jī)制 insert into orders(order_num,order

33、_date,cust_num) values(200,'2007-04-01',1019) --訂單 insert into items(item_num,order_num,prod_num,supp_code,quantity) values(1, 200, 2, 'HSC', 2) --訂單細(xì)項(xiàng)一 insert into items(item_num,order_num,prod_num,su

34、pp_code,quantity) values(2, 200, 6, 'HSC', 2) --訂單細(xì)項(xiàng)二 COMMIT TRAN --如果沒有錯(cuò)誤就認(rèn)可該交易end trybegin catch --發(fā)生錯(cuò)誤的處理機(jī)制 ROLLBACK TRAN --回復(fù)該次交易end catchSET IDENTITY_INSERT orders ON;,36,14-7 SQL Server 的3種交易類型,交易是

35、以每個(gè)連線主,所以每個(gè)連線都有自己的交易,但是不同的交易卻可能鎖定相同的物件而造成死結(jié)(Deadlock)的狀況 在SQL Server 2005中交易的模式有3種,分別為:外顯交易 (Explicit Transaction)、自動(dòng)認(rèn)可交易(Autocommit Transaction)隱含交易 (Implicit Transaction),37,14-7 SQL Server 的3種交易類型,外顯交易:是明確定義交易的啟動(dòng)與

36、結(jié)束的一種交易,所以亦稱之為明確交易,也就是使用SQL交易敘述所指定的交易。自動(dòng)認(rèn)可交易:這是SQL Server 2005預(yù)設(shè)的交易管理模式。每一個(gè)T-SQL敘述句都會在完成時(shí)認(rèn)可或回復(fù)。敘述句如果成功地完成則便會自動(dòng)被認(rèn)可;如果是遇到任何錯(cuò)誤則被自動(dòng)復(fù)原。 隱含交易:隱含交易的意思就是說不用下BEGIN TRANSACTION也會被認(rèn)為在交易的狀態(tài)下。換句話說,從系統(tǒng)進(jìn)入隱含交易之後所有執(zhí)行的SQL敘述都會視為同一個(gè)交易,直到使

37、用COMMIT或是ROLLBACK時(shí)才算結(jié)束一個(gè)交易。,38,14-8 巢狀式交易,巢狀式交易(Nested Transaction)是指數(shù)個(gè)交易彼此以階層的方式互相連結(jié),而成為巢狀式的結(jié)構(gòu)。@@TRANCOUNT為一整數(shù)之全域性變數(shù),它指出目前交易的巢狀階層(Nested Level) BEGIN TRANSACTION敘述會將@@TRANCOUNT加1 ROLLBACK TRANSACTION敘述則會將@@TRANCOUNT

38、設(shè)定為0 COMMIT TRANSACTION或COMMIT WORK敘述會將@@TRANCOUNT減1,39,14-9 分散式交易,分散式交易(Distributed Transaction)是指一交易使用到多個(gè)伺服器的資源。SQL Server 2005亦支援分散式交易,允許使用者在一交易中修訂多個(gè)伺服器資料庫的資料,一分散式交易會使用到下列系統(tǒng)軟體: 資源管理員(Resource Manager) 交易管理員(Transac

39、tion Manager) 二階段認(rèn)可(Two-phase Commit/2PC),40,14-9 分散式交易,資源管理員(Resource Manager)資源管理員為管控用於分散式交易資源的系統(tǒng)軟體,一分散式交易是由各別資源管理員的地區(qū)性交易(Local Transaction)所組成的。在分散式交易中,每一資源管理員都必須負(fù)責(zé)本身地區(qū)性交易的COMMIT或是ROLLBACK工作,而且要與其他的資源管理員相互協(xié)調(diào)。SQL Ser

40、ver本身即扮演著資源管理員的角色。,41,14-9 分散式交易,交易管理員(Transaction Manager)交易管理員為管控分散式交易COMMIT或ROLLBACK的系統(tǒng)軟體,它會協(xié)調(diào)各個(gè)資源管理員,以保證所有包含於一分散式交易的地區(qū)性交易能夠一起被COMMIT或是一起被ROLLBACK,Microsoft的分散式交易管理員(Distributed Transaction Coordinator/DTC)扮演著交易管理員的角

41、色。,42,14-9 分散式交易,二階段認(rèn)可(Two-phase Commit/2PC)準(zhǔn)備階段交易管理員送出一「準(zhǔn)備COMMIT」要求給每一資源管理員,每一資源管理員會去執(zhí)行地區(qū)性交易,完成後會只保有最低的必要系統(tǒng)資源(以保證資料的完整性),並傳回交易成功的訊息給交易管理員。確認(rèn)階段如果每一資源管理員於準(zhǔn)備階段都COMMIT成功,則交易管理員會送出「COMMIT命令」給一資源管理員。此時(shí)每一資源管理員會立刻將交易記錄為「已完成

42、」,並且釋出佔(zhàn)用的系統(tǒng)資源。如果任一資源管理員於準(zhǔn)備階段傳回錯(cuò)誤訊息,則交易管理員會送出「ROLLBACK命令」給每一資源管理員。,43,14-10 選擇交易隔離層級,交易隔離層級(Isolation Level)是一種機(jī)制,讓我們可以動(dòng)態(tài)的調(diào)整SQL Server於一連線內(nèi)的鎖定狀況。 交易隔離層級將存取共同資料的多個(gè)交易加以隔離,以決定一交易接受「不一致資料」的程度。低交易隔離層級可以增加系統(tǒng)並行處理的程度,但是會降低資料存取的

43、正確性。高交易隔離層級能夠讀取正確的資料,但是會降低系統(tǒng)並行處理的程度,44,14-10 選擇交易隔離層級,交易隔離層級決定了SQL Server使用鎖定機(jī)制的方式與程度以解決並行性控制上發(fā)生的問題。不淨(jìng)式讀取(Dirty Read):或稱中途讀取,意思就是說在交易讀取到未經(jīng)認(rèn)可的中途資料。 不可重複式讀取(Nonrepeatable Read):意思就是說在交易中讀取到的資料被其他交易改變了。 幽靈讀取(Phantom Re

44、ad):意思就是說交易中的資料表被其他交易改變了。,45,14-10 選擇交易隔離層級,SQL Server 2005支援以下ANSI SQL所定義的4種交易隔離層級: 讀取未認(rèn)可 (Read Uncommitted,隔離交易的最低等級,僅能確保不會讀取實(shí)體上已損毀的資料) 讀取認(rèn)可(Read Committed,SQL Server的預(yù)設(shè)值) 可重覆讀取(Repeatable Read) 可序列化(Serializable,隔

45、離交易的最高等級,使交易完全與其他交易隔離),46,14-10 選擇交易隔離層級,表14-10.1 交易隔離層級的現(xiàn)象,Read Uncommitted與Read Committed屬於樂觀的並行性控制 Repeatable Read與Serializable則屬於悲觀的並行性控制,47,14-10 選擇交易隔離層級,根據(jù)選擇的交易隔離層級,當(dāng)存取資源時(shí),系統(tǒng)會使用鎖機(jī)制(Lock)鎖住該資源,以便免其他交易來存取而發(fā)生一些錯(cuò)誤的現(xiàn)

46、象。可使用SET TRANSACTION ISOLATION LEVEL敘述來設(shè)定交易隔離層級 語法結(jié)構(gòu):SET TRANSACTION ISOLATION LEVEL {READ COMMITTED | READ UNCOMMITTED | REPEATABLE READ | SERIALIZABLE},48,14-10 選擇交易隔離層級,SET LOCK_TIMEOUT敘述語法結(jié)構(gòu):SET LOCK_TIMEOUT timeo

47、ut_period功能:宣告一SQL敘述等待一鎖機(jī)制被釋放的時(shí)間(TIME-OUT),以千分之一秒為單位,-1表示永久的等待,但永久等待很容易造成死結(jié),此為系統(tǒng)預(yù)設(shè)值 。 範(fàn)例14-10.1:請?jiān)O(shè)定TIME-OUT為1,800毫秒,然後查詢該設(shè)定值。set lock_timeout 1800select @@lock_timeout,49,14-11鎖定與死結(jié),SQL Server擁有多個(gè)資料粒度(Granulari

48、ty)的鎖定(Lock),允許交易鎖定不同類型的資源。為了把鎖定的成本降至最低,SQL Server會自動(dòng)依照交易的適當(dāng)層級來鎖定資源。鎖定於較小的資料粒度如資料列則可以提高並行性,但如果鎖定太多的資料列則會因?yàn)槌钟懈嗟逆i定而造成系統(tǒng)的負(fù)擔(dān),可能反而不如直接鎖定資料表。鎖定於較大的資料粒度如資料表,從並行性的角度來看會因?yàn)殒i定整個(gè)資料表而限制其他交易對於該資料表其他部份的存取。但由於必須維持的鎖定較少,因此系統(tǒng)的負(fù)擔(dān)較低。,50

49、,14-11鎖定與死結(jié),除了資料類型鎖定之外,還提供不同的資料鎖定模式:共用鎖定(S/Shared Lock):用於不作更新資料的讀取作業(yè),例如 SELECT敘述句。 獨(dú)佔(zhàn)鎖定(X/eXclusive Lock):用於資料修改動(dòng)作,例如INSERT、UPDATE以及DELETE。更新鎖定(U/Update Lock):更新(U)鎖定可防止常見的死結(jié)。 意圖鎖定(I/Intent Lock):意圖鎖定主要是用來防止其他交易修改較

50、高層級的資源,而導(dǎo)致較低層級的鎖定失效與改進(jìn)SQL Server偵測資料粒度較高層級鎖定衝突的效率。,51,14-11鎖定與死結(jié),有些鎖定可以同時(shí)發(fā)生在資源(換句話說就是不同的交易同時(shí)對一個(gè)資源發(fā)出鎖定)上,但有些就不行,稱之為鎖定模式的相容性,如下表所列。,52,14-11鎖定與死結(jié),死結(jié):當(dāng)二或多個(gè)工作各自具有某個(gè)資源的鎖定,但其他工作嘗試要鎖定此資源,而造成工作永久封鎖彼此時(shí)就發(fā)生死結(jié) ,例如:交易 A 取得資料列 1 的共用(

51、S)鎖定。交易 B 取得資料列 2 的共用(S)鎖定。交易 A 現(xiàn)在要求資料列 2 的獨(dú)佔(zhàn)(X)鎖定,但會被封鎖直到交易 B 完成並釋出對資料列 2 的共用(S)鎖定為止 交易 B 現(xiàn)在要求資料列 1 的獨(dú)佔(zhàn)(X)鎖定,但會被封鎖直到交易 A 完成並釋出對資料列 1 的共用(S)鎖定為止。,53,14-11鎖定與死結(jié),在這種情況下,等到交易B完成後,交易A才能完成;但交易B被交易A封鎖了。這個(gè)狀況也稱為「循環(huán)相依性」(Cyclic

52、 Dependency),54,14-11鎖定與死結(jié),降低死結(jié)發(fā)生率的建議方式: 以相同的順序來存取物件 將交易維持在單一批次中且愈短愈好 在交易中避免使用者互動(dòng) 使用較低的隔離等級,55,14-12 本章總結(jié),資料庫的異動(dòng)必須以交易的方式執(zhí)行,這樣才能確保資料的完整性與一致性 交易是一個(gè)單一工作單元該工作邏輯單元必須呈現(xiàn)出四種屬性,才能有資格成為一筆交易,分別為:單元性(Atomicity)、一致性(Consistency)

53、、隔離性(Isolation) 以及耐久性(Durability) 屬性,簡稱為ACID 交易管理在DBMS是由錯(cuò)誤回復(fù)(Failure Recovery)和並行控制(Concurrency Control)兩個(gè)主要機(jī)制來達(dá)成。 「錯(cuò)誤回復(fù)」機(jī)制是維持交易處理的「單元性」和「耐久性」,而「並行控制」機(jī)制是在維持「隔離性」和「一致性」 。,56,14-12 本章總結(jié),在一個(gè)多元程式(Multiprogramming)或多工(Multi

54、-tasking)的資料庫系統(tǒng)中,必須提供「並行控制」(Concurrency Control)機(jī)制,否則將會發(fā)生遺失更新問題(Lost Update Program)、暫時(shí)更新問題(Temporary Update Problem,或稱之為中途讀取問題Dirty Read Problem)、不可重複讀取(Nonrepeatable Read)以及幽靈讀取(Phantom Read)等問題。 SQL Server支援4種交易隔離層級

55、-- Read Uncommitted、Read Committed、Repeatable Read以及Serializable,57,14-12 本章總結(jié),Read Uncommitted的層級最低,使用的系統(tǒng)資源最少,但是系統(tǒng)並行處理性最高,Serializable的層級最高,使用的系統(tǒng)資源最多,但是系統(tǒng)並行處理性最低。 SQL Server會每隔一段時(shí)間,將那些已被修改過的資料寫入資料庫,這種動(dòng)作我們稱之為查核點(diǎn)。 所謂的分散

56、式交易(Distributed Transaction)是指一交易使用到多個(gè)伺服器的資源,一分散式交易會使用資源管理員(Resource Manager)、交易管理員(Transaction Manager)以及二階段認(rèn)可(Two-phase Commit/2PC),58,14-12 本章總結(jié),在SQL Server 2005資料鎖定的模式可分為共用鎖定(S/Shared Lock)、獨(dú)佔(zhàn)鎖定(X/eXclusive Lock)、更新鎖

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論