C# EF更新事务中的FormView
我想在一个事务中更新两个FormView。如果其中一个失败,另一个也应该失败。FormView有自己的实体数据源C# EF更新事务中的FormView,c#,asp.net,entity-framework,transactions,C#,Asp.net,Entity Framework,Transactions,我想在一个事务中更新两个FormView。如果其中一个失败,另一个也应该失败。FormView有自己的实体数据源 button1_click(..........) { formview1.updateItem(true); formview2.updateItem(true); } 好吧,这可能不是世界上最简单的事情 基本的答案是:是的,你能做到。如果updateItem方法打开数据库连接,代码将类似于此 using (TransactionScope scope = new T
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();
}