C# .NET EFCore 性能优化

查询缓存优化

利用EF Core的查询缓存机制,相同的查询语句会被缓存,避免重复编译。对于频繁执行的查询,可以显式启用缓存:

csharp 复制代码
var compiledQuery = EF.CompileQuery(
    (DbContext context, int id) => 
        context.Products.FirstOrDefault(p => p.Id == id));

批量操作处理

使用AddRangeRemoveRange替代单条操作,结合SaveChanges的批处理能力:

csharp 复制代码
context.Products.AddRange(productList);
context.SaveChanges();

启用批处理需要配置SQL Server提供程序:

csharp 复制代码
optionsBuilder.UseSqlServer(connectionString, 
    o => o.MaxBatchSize(100));

延迟加载慎用

导航属性的延迟加载会导致N+1查询问题。显式加载或预加载更高效:

csharp 复制代码
var orders = context.Orders
    .Include(o => o.OrderDetails)
    .ToList();

异步操作提升吞吐量

使用async/await避免线程阻塞:

csharp 复制代码
var product = await context.Products
    .FirstOrDefaultAsync(p => p.Id == id);

跟踪行为控制

只读查询禁用变更跟踪:

csharp 复制代码
var products = context.Products
    .AsNoTracking()
    .Where(p => p.Price > 100)
    .ToList();

索引优化

确保查询字段有数据库索引:

csharp 复制代码
modelBuilder.Entity<Product>()
    .HasIndex(p => p.CategoryId);

SQL日志监控

开发阶段开启日志检查生成SQL:

csharp 复制代码
optionsBuilder.UseLoggerFactory(loggerFactory)
    .EnableSensitiveDataLogging();

分页查询优化

使用Skip/Take时确保有序:

csharp 复制代码
var pagedData = context.Products
    .OrderBy(p => p.Id)
    .Skip(20)
    .Take(10)
    .ToList();

原始SQL复杂查询

高性能场景直接执行SQL:

csharp 复制代码
var products = context.Products
    .FromSqlRaw("SELECT * FROM Products WITH (NOLOCK)")
    .ToList();

连接池配置

调整DbContext池大小避免资源争用:

csharp 复制代码
services.AddDbContextPool<AppDbContext>(options => 
    options.UseSqlServer(connectionString), poolSize: 128);
相关推荐
歪歪1005 小时前
在C#中详细介绍一下Visual Studio中如何使用数据可视化工具
开发语言·前端·c#·visual studio code·visual studio·1024程序员节
Eiceblue5 小时前
如何通过 C# 高效读写 Excel 工作表
c#·visual studio·1024程序员节
张人玉5 小时前
WPF 触发器详解:定义、种类与示例
c#·wpf·1024程序员节·布局控件
武子康6 小时前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节
追逐时光者8 小时前
全面的 C#/.NET 图表构建解决方案,助力快速实现图表开发需求!
后端·.net
阿登林9 小时前
C# .NET Core中Chart图表绘制与PDF导出
c#·1024程序员节
九皇叔叔12 小时前
Java循环结构全解析:从基础用法到性能优化
java·开发语言·性能优化
yi碗汤园14 小时前
【一文了解】八大排序-插入排序、希尔排序
开发语言·算法·unity·c#·1024程序员节
小朩15 小时前
数据结构C语言
数据结构·c#·1024程序员节
CN.LG16 小时前
C# 企业微信机器人消息推送
c#·企业微信·1024程序员节·机器人推送