交易中的EF更新表单视图

时间:2012-06-19 11:56:33

标签: c# asp.net entity-framework transactions

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

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

1 个答案:

答案 0 :(得分: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();
}