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

使用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
本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段宣告,且在文章頁面明顯位置給出原文連線,否則保留追究法律責任的權利。