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);
相关推荐
The Shio1 小时前
OptiByte 操练场:面向 IoT/嵌入式的协议可视化调试工具
网络·嵌入式硬件·物联网·c#·.net·业界资讯·iot
龙侠九重天2 小时前
C# 调用 TensorFlow:迁移学习与模型推理实战指南
人工智能·深度学习·机器学习·c#·tensorflow·迁移学习·tensorflow.net
MU在掘金916953 小时前
布局分析:检测XML嵌套过深
性能优化
Highcharts.js3 小时前
Highcharts React 性能优化指南|使用 useMemo 渲染五万数据点不卡顿
react.js·性能优化·react hooks·highcharts·usememo·大数据渲染·前端性能
我是唐青枫4 小时前
C#.NET YARP 认证授权实战:在网关层统一接入 JWT
开发语言·c#·.net
程序leo源4 小时前
Linux深度理解
linux·运维·服务器·c语言·c++·青少年编程·c#
步步为营DotNet4 小时前
探索.NET 11:ASP.NET Core 10 云原生应用开发实践
云原生·asp.net·.net
白菜上路4 小时前
C# .net 生成版本号自动变更
c#·.net·visual studio
加号34 小时前
【C#】 通过 Python.NET 调用 Python pyd 扩展模块:多类交互与参数传递实践指南
python·c#·.net
故事还在继续吗4 小时前
嵌入式 C 语言程序性能优化
c语言·开发语言·性能优化