關(guān)于WCF事物處理揭秘
在我們的程序中,無(wú)論是JAVA也好,還是C也好,最不好處理的就是關(guān)于事物,本人比較關(guān)注WCF,現(xiàn)在就一起分析一下關(guān)于WCF事物處理的方案吧!單純的事務(wù)存在著下面三個(gè)問(wèn)題
1) 臟讀:簡(jiǎn)單的說(shuō)就是事務(wù)一在某一時(shí)刻更改了數(shù)據(jù),恰恰這個(gè)更改的數(shù)據(jù)被事務(wù)二讀取,而事務(wù)一卻最終失敗,導(dǎo)致數(shù)據(jù)回滾,那事務(wù)二就是一個(gè)受騙者
2) 非可重復(fù)性讀取:同一數(shù)據(jù)每次讀取的結(jié)果都不一樣就是非可重復(fù)讀取。比如事務(wù)一要讀取的數(shù)據(jù)務(wù)二改變,這就是非可重復(fù)性讀取
3) 幻讀:很簡(jiǎn)單,比如事務(wù)一在查詢數(shù)據(jù)中,事務(wù)二卻插入了一個(gè)符合查詢條件的數(shù)據(jù),這樣就造成新插入數(shù)據(jù)的幻讀。
三種WCF事物處理問(wèn)題的解釋可能比較難于理解,其實(shí)簡(jiǎn)單的說(shuō),臟讀是讀了別人正在更改的數(shù)據(jù),而可重復(fù)讀取是更改了別人正在讀的數(shù)據(jù),而幻讀呢則是讀了別人還未來(lái)得及插入,更改或者刪除的數(shù)據(jù),我想這樣理解就簡(jiǎn)單多了。針對(duì)上面不同的問(wèn)題,可以設(shè)置事務(wù)的不同隔離方式來(lái)防止問(wèn)題的發(fā)生,事務(wù)的隔離方式又包括
1) Any: 組件的隔離級(jí)別是從調(diào)用組件的隔離級(jí)別獲得的。如果組件是根組件,則隔離級(jí)別用于 Serializable 中。
2) ReadUncommitted:讀取未提交數(shù)據(jù),該方式在讀取數(shù)據(jù)時(shí)保持共享鎖定以避免讀取已修改的數(shù)據(jù),但在事務(wù)結(jié)束前可以更改這些數(shù)據(jù),這導(dǎo)致非可重復(fù)讀取或幻讀。
3) ReadCommitted:讀取提交數(shù)據(jù), 發(fā)出共享鎖定并允許非獨(dú)占方式的鎖定。該方式與讀取未提交數(shù)據(jù)相相似,這種方式看似和讀取未提交數(shù)據(jù)相似,但有一個(gè)區(qū)別,事務(wù)的只讀鎖在移到下一行的時(shí)候,會(huì)解鎖,而寫入鎖卻只有在事務(wù)完成或者被中止后才解鎖,事務(wù)要等待所有寫入鎖解鎖。
4) RepeatableRead:可重復(fù)性讀取,與讀取提交數(shù)據(jù)相似,在查詢中使用的所有數(shù)據(jù)上放置鎖,以防止其他用戶更新這些數(shù)據(jù)。防止非可重復(fù)讀取,但幻讀行仍有可能發(fā)生。該方式是只讀鎖也要等到事務(wù)結(jié)束或者中止才解除
5) Serializable:在完成事務(wù)前防止更新或插入。
從上面的描述看,幾種隔離方式比較難于區(qū)分,WCF事物處理是很難的一件事,但是記住這些更方便的了解隔離方式
隔離級(jí)別 |
ReadUncommitted |
ReadCommitted |
RepeatableRead |
Serializable | ||
臟讀 |
Yes |
No |
No |
No | ||
非可重復(fù)性讀取 |
Yes |
Yes |
No |
No | ||
幻讀 |
Yes |
Yes |
Yes |
No |
從上表可以看出隔離方式除了Any之外,一級(jí)比一級(jí)嚴(yán)厲。Any是一脈相承的,如果它沒(méi)有可繼承的,它將是最嚴(yán)厲的Serializable