自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C#語言操縱數(shù)據(jù)庫事務(wù)

開發(fā) 后端
本文介紹C#數(shù)據(jù)庫事務(wù)是指作為單個邏輯工作單元執(zhí)行的一系列操作。C#數(shù)據(jù)庫事務(wù)正是用來保證這種情況下交易的平穩(wěn)性和可預(yù)測性的技術(shù)。

什么是C#數(shù)據(jù)庫事務(wù)

C#數(shù)據(jù)庫事務(wù)是指作為單個邏輯工作單元執(zhí)行的一系列操作。

設(shè)想網(wǎng)上購物的一次交易,其付款過程至少包括以下幾步數(shù)據(jù)庫操作:
◆更新客戶所購商品的庫存信息
◆保存客戶付款信息--可能包括與銀行系統(tǒng)的交互
◆生成訂單并且保存到數(shù)據(jù)庫中
◆更新用戶相關(guān)信息,例如購物數(shù)量等等

正常的情況下,這些操作將順利進(jìn)行,最終交易成功,與交易相關(guān)的所有數(shù)據(jù)庫信息也成功地更新。但是,如果在這一系列過程中任何一個環(huán)節(jié)出了差錯,例如在更新商品庫存信息時發(fā)生異常、該顧客銀行帳戶存款不足等,都將導(dǎo)致交易失敗。一旦交易失敗,數(shù)據(jù)庫中所有信息都必須保持交易前的狀態(tài)不變,比如最后一步更新用戶信息時失敗而導(dǎo)致交易失敗,那么必須保證這筆失敗的交易不影響數(shù)據(jù)庫的狀態(tài)--庫存信息沒有被更新、用戶也沒有付款,訂單也沒有生成。否則,數(shù)據(jù)庫的信息將會一片混亂而不可預(yù)測。

C#數(shù)據(jù)庫事務(wù)正是用來保證這種情況下交易的平穩(wěn)性和可預(yù)測性的技術(shù)。

C#數(shù)據(jù)庫事務(wù)的ACID屬性

事務(wù)處理可以確保除非事務(wù)性單元內(nèi)的所有操作都成功完成,否則不會永久更新面向數(shù)據(jù)的資源。通過將一組相關(guān)操作組合為一個要么全部成功要么全部失敗的單元,可以簡化錯誤恢復(fù)并使應(yīng)用程序更加可靠。一個邏輯工作單元要成為事務(wù),必須滿足所謂的ACID(原子性、一致性、隔離性和持久性)屬性:

◆原子性

事務(wù)必須是原子工作單元;對于其數(shù)據(jù)修改,要么全都執(zhí)行,要么全都不執(zhí)行。通常,與某個事務(wù)關(guān)聯(lián)的操作具有共同的目標(biāo),并且是相互依賴的。如果系統(tǒng)只執(zhí)行這些操作的一個子集,則可能會破壞事務(wù)的總體目標(biāo)。原子性消除了系統(tǒng)處理操作子集的可能性。

◆一致性

事務(wù)在完成時,必須使所有的數(shù)據(jù)都保持一致狀態(tài)。在相關(guān)數(shù)據(jù)庫中,所有規(guī)則都必須應(yīng)用于事務(wù)的修改,以保持所有數(shù)據(jù)的完整性。事務(wù)結(jié)束時,所有的內(nèi)部數(shù)據(jù)結(jié)構(gòu)(如 B 樹索引或雙向鏈表)都必須是正確的。某些維護(hù)一致性的責(zé)任由應(yīng)用程序開發(fā)人員承擔(dān),他們必須確保應(yīng)用程序已強(qiáng)制所有已知的完整性約束。例如,當(dāng)開發(fā)用于轉(zhuǎn)帳的應(yīng)用程序時,應(yīng)避免在轉(zhuǎn)帳過程中任意移動小數(shù)點(diǎn)。

◆隔離性

由并發(fā)事務(wù)所作的修改必須與任何其它并發(fā)事務(wù)所作的修改隔離。事務(wù)查看數(shù)據(jù)時數(shù)據(jù)所處的狀態(tài),要么是另一并發(fā)事務(wù)修改它之前的狀態(tài),要么是另一事務(wù)修改它之后的狀態(tài),事務(wù)不會查看中間狀態(tài)的數(shù)據(jù)。這稱為可串行性,因?yàn)樗軌蛑匦卵b載起始數(shù)據(jù),并且重播一系列事務(wù),以使數(shù)據(jù)結(jié)束時的狀態(tài)與原始事務(wù)執(zhí)行的狀態(tài)相同。當(dāng)事務(wù)可序列化時將獲得最高的隔離級別。在此級別上,從一組可并行執(zhí)行的事務(wù)獲得的結(jié)果與通過連續(xù)運(yùn)行每個事務(wù)所獲得的結(jié)果相同。由于高度隔離會限制可并行執(zhí)行的事務(wù)數(shù),所以一些應(yīng)用程序降低隔離級別以換取更大的吞吐量。

◆持久性

C#數(shù)據(jù)庫事務(wù)完成之后,它對于系統(tǒng)的影響是永久性的。該修改即使出現(xiàn)致命的系統(tǒng)故障也將一直保持。
DBMS的責(zé)任和我們的任務(wù)

企業(yè)級的數(shù)據(jù)庫管理系統(tǒng)(DBMS)都有責(zé)任提供一種保證事務(wù)的物理完整性的機(jī)制。就常用的SQL Server2000系統(tǒng)而言,它具備鎖定設(shè)備隔離事務(wù)、記錄設(shè)備保證事務(wù)持久性等機(jī)制。因此,我們不必關(guān)心數(shù)據(jù)庫事務(wù)的物理完整性,而應(yīng)該關(guān)注在什么情況下使用數(shù)據(jù)庫事務(wù)、事務(wù)對性能的影響,如何使用事務(wù)等等。

本文將涉及到在.net框架下使用C#語言操縱數(shù)據(jù)庫事務(wù)的各個方面。

【編輯推薦】

  1. 分析C#不安全代碼
  2. 淺析C#調(diào)用ImageAnimator
  3. C#連接Access、SQL Server數(shù)據(jù)庫
  4. 淺談C#固定的和活動的變量
  5. 介紹C#中的值類型
責(zé)任編輯:佚名 來源: CSDN
相關(guān)推薦

2009-08-07 17:04:41

C#數(shù)據(jù)庫

2024-04-18 09:56:16

2009-08-11 13:35:13

C# Berkeley

2009-03-19 10:08:09

C#數(shù)據(jù)庫查詢

2010-10-26 15:21:11

連接Oracle數(shù)據(jù)庫

2009-08-24 18:09:13

C#調(diào)用Oracle數(shù)

2009-08-17 17:42:57

C#數(shù)據(jù)庫操作類

2009-08-25 14:05:06

C#連接數(shù)據(jù)庫代碼

2009-07-31 17:01:21

C#存取Access數(shù)

2009-09-04 17:23:21

C#數(shù)據(jù)庫連接對象

2009-08-07 16:19:00

C#下數(shù)據(jù)庫編程

2009-08-25 12:50:32

數(shù)據(jù)庫常用C#代碼

2009-08-07 16:19:00

C#下數(shù)據(jù)庫編程

2009-08-12 14:27:36

訪問MySQL數(shù)據(jù)庫C# ODBC

2011-03-04 11:08:46

ADO.NET數(shù)據(jù)庫

2009-09-03 16:17:12

C#操縱系統(tǒng)菜單

2009-09-04 17:53:23

C#增加數(shù)據(jù)庫數(shù)據(jù)

2009-08-19 16:30:55

C#操作Access數(shù)

2009-08-11 15:22:57

C#讀Excel

2009-08-10 18:05:19

C#數(shù)據(jù)庫查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號