我想在事务中更新两个表单视图。如果其中一个失败,另一个也会失败。 Formviews有自己的实体数据源。
button1_click(..........)
{
formview1.updateItem(true);
formview2.updateItem(true);
}
答案 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();
}