4

我想更新事务中的两个表单视图。如果其中一个失败,另一个也应该失败。Formviews 有自己的实体数据源。

button1_click(..........)
{
   formview1.updateItem(true);
   formview2.updateItem(true);
}
4

1 回答 1

2

好的,所以这可能不是世界上最简单的事情。

基本的答案是,是的,你可以做到。如果 updateItem 方法打开数据库连接,代码将与此类似。

using (TransactionScope scope = new TransactionScope())
{
    formview1.updateItem(true);
    formview2.updateItem(true);
    scope.Complete();
}

另一方面,如果在调用 updateItem 时连接已经打开,那么您将需要做更多类似的事情

using (TransactionScope scope = new TransactionScope())
{
    formview1.Connection.EnlistTransaction(Transcation.Current);
    formview2.Connection.EnlistTransaction(Transcation.Current);
    formview1.updateItem(true);
    formview2.updateItem(true);
    scope.Complete();
}
于 2012-07-30T11:42:23.427 回答