0

0

C#中如何优化EF Core的保存操作?有哪些最佳实践?

星降

星降

发布时间:2025-10-11 16:17:01

|

653人浏览过

|

来源于php中文网

原创

合理减少SaveChanges调用次数,使用AddRange等批量方法,禁用自动追踪,结合原生批量库如EFCore.BulkExtensions,并显式管理事务,避免冗余查询,可显著提升EF Core保存性能。

c#中如何优化ef core的保存操作?有哪些最佳实践?

在使用 EF Core 时,保存操作(SaveChanges)如果处理不当,很容易成为性能瓶颈。尤其在批量插入、更新或涉及大量实体的场景下,优化显得尤为重要。以下是提升 EF Core 保存效率的一些关键做法和最佳实践。

减少 SaveChanges 的调用次数

每次调用 SaveChanges() 都会开启一个数据库事务并执行 SQL,频繁调用会导致大量往返开销。

  • 将多个实体的增删改操作合并到一次 SaveChanges() 中提交。
  • 在循环中避免每次操作都调用 SaveChanges(),应先完成所有变更再统一提交。
示例:
foreach (var item in items)
{
    context.Products.Add(item); // 不在此处 SaveChanges
}
context.SaveChanges(); // 批量提交一次

使用 AddRange 和 UpdateRange 提升批量操作效率

EF Core 提供了 AddRangeUpdateRangeRemoveRange 方法,能更高效地处理集合操作。

  • 相比逐个添加,AddRange 能减少内部状态管理的开销。
  • 适用于导入数据、初始化配置等场景。
示例:
context.AddRange(products);
context.SaveChanges();

禁用自动追踪以提高性能

如果你只是做写入操作而不需要查询追踪,可以临时关闭变更追踪。

  • 使用 context.ChangeTracker.AutoDetectChangesEnabled = false 减少开销。
  • 对于只写场景,考虑使用 AsNoTracking 查询,但注意这主要影响查询阶段。
  • 在大批量插入前,可手动控制变更检测时机。

考虑使用原生批量插入库

EF Core 原生不支持真正的批量 INSERT(如 INSERT INTO ... VALUES (...), (...), (...)),默认是逐条插入。

Runway
Runway

Runway是一个AI创意工具平台,它提供了一系列强大的功能,旨在帮助用户在视觉内容创作、设计和开发过程中提高效率和创新能力。

下载
  • 使用第三方库如 EFCore.BulkExtensionsNpgsql.EntityFrameworkCore.PostgreSQL(PostgreSQL)等提供批量支持。
  • BulkInsert 可显著提升大数据量写入速度(成百上千条记录以上)。
示例(EFCore.BulkExtensions):
context.BulkInsert(products); // 单次高效插入

合理使用事务控制

当需要保证多个 SaveChanges 操作的原子性时,显式使用事务更安全且可控。

  • context.Database.BeginTransaction() 包裹多个保存操作。
  • 避免长时间持有事务,防止锁表或连接占用。
示例:
using var transaction = context.Database.BeginTransaction();
try
{
    context.Orders.AddRange(orders);
    context.SaveChanges();

    context.OrderItems.AddRange(items);
    context.SaveChanges();

    transaction.Commit();
}
catch
{
    transaction.Rollback();
    throw;
}

避免不必要的查询和加载

在保存前不要触发无意义的查询,否则可能拉取大量数据进入上下文,拖慢整体性能。

  • 不要为了设置外键而去查询整个主实体,直接设置导航属性或外键字段即可。
  • 使用“分离状态”或“影子属性”减少内存占用
推荐方式:
context.Entry(order).State = EntityState.Unchanged; // 标记已存在,避免查询
product.OrderId = orderId; // 直接赋值外键

监控和诊断性能问题

启用日志输出,查看实际生成的 SQL 和执行时间。

  • DbContext 配置中启用详细日志(如 Microsoft.EntityFrameworkCore.Database.Command)。
  • 使用工具MiniProfilerApplication Insights 分析耗时操作。
基本上就这些。掌握这些方法后,EF Core 的保存操作可以既稳定又高效。关键是根据数据量级选择合适的策略——小批量用内置 API,大批量引入扩展库,并始终关注上下文生命周期和变更追踪成本。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

683

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

347

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

676

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

575

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

417

2024.04.29

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.4万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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