C#在EntityFramework中实现事务回滚
短信预约 -IT技能 免费直播动态提醒
在使用Entity Framework为主从表添加数据,当一个表添加数据成功,另一个表添加数据失败,这时候就需要用到事务回滚。
比如有以下关系的2张表。
客户端使用TransactionScope类可以实现事务回滚。
class Program
{
static void Main(string[] args)
{
try
{
using (TransactionScope ts = new TransactionScope())
{
using (CountryDetailsEntities db = new CountryDetailsEntities())
{
Country country = new Country();
country.CountryName = "USA";
db.Countries.Add(country);
db.SaveChanges();
if (country.CountryID > 0)
{
int a = 0;
int total = 10 / a;
State state = new State();
state.CountryID = country.CountryID;
state.StateName = "NewYork";
db.States.Add(state);
db.SaveChanges();
}
}
ts.Complete();
}
}
catch (Exception ex)
{
throw;
}
}
}
以上,在添加State表数据的时候,模拟了一个异常,通过断点调试执行完毕,发现数据库中没有增加任何数据。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对编程网的支持。如果你想了解更多相关内容请查看下面相关链接
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341