使用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
使用TransactionScope做分布式事務協調