.NET如何使用Entity Framework Core执行事务

星降
发布: 2025-11-03 23:13:02
原创
1032人浏览过
答案:EF Core通过BeginTransaction或TransactionScope确保多操作原子性。使用DbContext.Database.BeginTransaction()可显式控制事务,配合SaveChanges()实现提交与回滚;异步场景应使用BeginTransactionAsync和SaveChangesAsync避免阻塞;跨上下文事务可用TransactionScope,但会升级为分布式事务,需谨慎使用。合理管理事务范围与异常处理,能有效保障数据一致性并提升性能。

.net如何使用entity framework core执行事务

在.NET中使用Entity Framework Core执行事务,主要是为了确保多个数据库操作要么全部成功,要么全部回滚,保持数据的一致性。EF Core提供了简单而强大的方式来管理事务,尤其适用于需要跨多个表或上下文协调操作的场景。

使用DbContext开启事务

EF Core默认会在调用 SaveChanges() 时自动创建一个事务。如果你有多个操作需要放在同一个事务中,可以显式地使用 Database.BeginTransaction() 来控制事务边界。

以下是一个典型的事务使用示例:

using (var context = new AppDbContext())
{
    using var transaction = context.Database.BeginTransaction();
    try
    {
        // 操作1:添加订单
        var order = new Order { Total = 100 };
        context.Orders.Add(order);
        context.SaveChanges();

        // 操作2:更新库存
        var product = context.Products.Find(1);
        product.Stock -= 1;
        context.SaveChanges();

        // 提交事务
        transaction.Commit();
    }
    catch (Exception)
    {
        // 出错时回滚
        transaction.Rollback();
        throw;
    }
}
登录后复制

异步操作中的事务处理

在异步编程中,应使用 BeginTransactionAsync() 方法以避免阻塞线程。同时,保存操作也应使用异步版本。

示例如下:

达芬奇
达芬奇

达芬奇——你的AI创作大师

达芬奇 144
查看详情 达芬奇
using (var context = new AppDbContext())
{
    using var transaction = await context.Database.BeginTransactionAsync();
    try
    {
        var order = new Order { Total = 200 };
        context.Orders.Add(order);
        await context.SaveChangesAsync();

        var product = await context.Products.FindAsync(2);
        product.Stock -= 1;
        await context.SaveChangesAsync();

        await transaction.CommitAsync();
    }
    catch (Exception)
    {
        await transaction.RollbackAsync();
        throw;
    }
}
登录后复制

跨多个上下文的分布式事务(谨慎使用)

如果必须在多个 DbContext 实例之间共享事务,可以使用 TransactionScope。但这种方式会升级为分布式事务,依赖MSDTC或在.NET Core中需启用特定支持(如使用 SQL Server 和 Windows 环境)。

示例代码:

using var scope = new TransactionScope(TransactionScopeAsyncFlowOption.Enabled);
try
{
    using (var context1 = new AppDbContext())
    {
        context1.Orders.Add(new Order { Total = 150 });
        context1.SaveChanges();
    }

    using (var context2 = new AppDbContext())
    {
        var product = context2.Products.Find(3);
        product.Stock -= 1;
        context2.SaveChanges();
    }

    scope.Complete(); // 提交
}
catch
{
    // 自动回滚
    throw;
}
登录后复制

注意:TransactionScope 在跨进程或容器化环境中可能不适用,建议尽量通过单个上下文设计来避免。

基本上就这些。合理使用事务能有效保证数据一致性,关键是在出错时及时回滚,且不要让事务持续太久,以免影响性能。EF Core的事务机制简洁实用,掌握好 BeginTransaction 和异常处理即可应对大多数场景。

以上就是.NET如何使用Entity Framework Core执行事务的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号