使用TransactionScope做分散式事務協調
//場景是使用在多個數據庫之間的協調,.NET 2.0使用一個新的型別 TransactionScope來進行協調,這與之前的COM+協調是相對來說更加方便的
//需要引用一個新的程式集:System.Transactions
//需要特別注意一個地方,TransactionScope預設使用的事務隔離級別為序列化,那可能會太過於嚴格。所以應該根據需要進行必要的調整
//注意:還是需要MSDTC服務支援的。請用net start msdtc啟用它
TransactionOptions options = new TransactionOptions();
options.Timeout = new TimeSpan(0, 0, 60);
options.IsolationLevel = IsolationLevel.ReadCommitted;
using (TransactionScope scope = new TransactionScope(options)) {
try
{
SqlConnection conn1 = new SqlConnection("server=(local);database=demo;integrated security=true");
conn1.Open();
SqlCommand cmd1 = conn1.CreateCommand();
cmd1.CommandText = "INSERT INTO Table1 VALUES(3)";
cmd1.ExecuteNonQuery();
SqlConnection conn2 = new SqlConnection("server=(local);database=northwind;integrated security=true");
conn2.Open();
SqlCommand cmd2 = conn2.CreateCommand();
cmd2.CommandText = "DROP TABLE Table1";
cmd2.ExecuteNonQuery();
scope.Complete();//提交分散式事務
}
catch (SqlException ex)
{
MessageBox.Show(ex.Message);
}
}
注意,TransactionScope不需要所謂的Rollback,只要沒有Complete,那麼在using語句塊跳出的時候,就自動地Rollback
作者:陳希章 出處:http://blog.csdn.net/chen_xizhang 本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段宣告,且在文章頁面明顯位置給出原文連線,否則保留追究法律責任的權利。 |