1. 程式人生 > >使用TransactionScope做分布式事務協調

使用TransactionScope做分布式事務協調

ransac true actions exception () adc open let oca

//場景是使用在多個數據庫之間的協調,.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

使用TransactionScope做分布式事務協調