//场景是使用在多个数据库之间的协调,.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