c# – 交易中的EF更新表单视图

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

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

最佳答案 好的,这可能不是世界上最简单的事情.

基本的答案是,你可以做到.如果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();
}
点赞