用上这几种.NET EF Core性能调优,查询性能飙升

1、避免在循环中进行查询操作:

避免在循环中进行查询操作,可以将查询结果缓存到内存中,然后对内存中的数据进行操作,可以提高性能。这种方式适合集合数据量少的数据,否则利大于弊。

// 不建议的方式:在循环中进行查询操作
foreach (var item in itemList)
{
    var result = context.Items.FirstOrDefault(i => i.Id == item.Id);
//执行逻辑
}
// 推荐的方式:将查询结果缓存到内存中,然后对内存中的数据进行操作
var itemIds = itemList.Select(i => i.Id).ToList();
var results = context.Items.Where(i => itemIds.Contains(i.Id)).ToList();
foreach (var item in itemList)
{
    var result = results.FirstOrDefault(r => r.Id == item.Id);
    //执行逻辑
}

2、避免使用懒加载:

避免使用懒加载,因为每次访问导航属性都会触发额外的数据库查询。使用显式加载或预先加载的技术可以提高性能。

// 不建议的方式:使用懒加载
var order = context.Orders.FirstOrDefault();
foreach (var item in order.Items)
{
  //执行逻辑
}
// 推荐的方式:使用预先加载
var order = context.Orders.Include(o => o.Items).FirstOrDefault();
foreach (var item in order.Items)
{
   //执行逻辑
}

3、合理使用Include方法:

Include方法可以在一次查询中获取所有相关的实体对象。但是,当涉及到大量数据时,Include方法会导致性能下降。可以使用手动链接查询代替Include方法。

// 不建议的方式:使用Include方法获取所有关联实体
var orders = context.Orders.Include(o => o.Items).ToList();

// 推荐的方式:使用手动链接查询代替Include方法
var orders = context.Orders
    .Join(context.OrderItems,
          o => o.Id,
          oi => oi.OrderId,
          (o, oi) => new { Order = o, OrderItem = oi })
    .ToList();

4、使用NoTracking方法:

使用NoTracking方法可以避免EF Core的跟踪功能。跟踪功能在更新和删除实体对象时非常有用,但是在只需要读取数据时,跟踪功能会导致额外的开销。使用NoTracking方法可以禁用跟踪功能,从而提高性能。

// 不建议的方式:使用默认跟踪功能
var order = context.Orders.FirstOrDefault();
// 推荐的方式:使用NoTracking方法
var order = context.Orders.AsNoTracking().FirstOrDefault();
//欢迎公众号:DOTNET开发跳槽

5、执行原始SQL查询:

有些情况下,使用原始的SQL语句可以比使用EF Core更高效。使用FromSqlRaw或者ExecuteSqlRaw方法可以执行原始SQL查询。

// 执行原始SQL查询
var orders = context.Orders.FromSqlRaw("SELECT * FROM Orders WHERE Status = 'Complete'").ToList();

6、使用EF.CompileAsyncQuery

EF.CompileAsyncQuery是EF Core的一个扩展方法,它可以将LINQ表达式编译为一个异步查询。相比于动态生成LINQ查询,使用EF.CompileAsyncQuery可以提高查询性能,减少不必要的内存分配。

编译后的查询可以多次调用,而不必每次动态生成查询表达式。这样可以避免不必要的内存分配和查询优化开销,提高查询性能。在EF Core 5.0及以上版本中,EF.CompileAsyncQuery已经成为了标准的扩展方法,无需进行任何特殊的安装或配置即可使用。它适用于查询条件固定的情况,当然也可以重新编译,不过频繁的编译会造成内存和性能的开销。示例如下:

using Microsoft.EntityFrameworkCore.Query;
// 定义一个异步查询
private static readonly Func<MyDbContext, int, Task<Order>> GetOrderById =
    EF.CompileAsyncQuery((MyDbContext context, int id) =>
        context.Orders.FirstOrDefaultAsync(o => o.Id == id));
// 调用异步查询
var order = await GetOrderById(context, 1);

结语

本文讲述了6种性能调优的方式,希望对大家有所帮助,尤其是面试的时候,当面试官问您有没有什么办法提高EF Core的性能,大家可以回答其中几个。当然上面的方法不是绝对的,需要根据实际场景来应用,比如Include方法在数据量小的情况下适合使用,数据量大的话就适得其反了。大家还有什么EF Core调优的方法,欢迎留言讨论或者吐槽本文。

来源公众号:DotNet开发跳槽

原文链接:https://www.cnblogs.com/xbhp/p/17292411.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:用上这几种.NET EF Core性能调优,查询性能飙升 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • 详解LINQ入门(中篇)

    详解LINQ入门(中篇) 1. LINQ是什么 LINQ(Language Integrated Query)是.NET Framework 3.5 引入的一项语言功能,它允许使用简洁明了的编程语法进行数据查询和操作。 LINQ分为两类:LINQ to Objects和LINQ to SQL。其中,LINQ to Objects用于操作对象集合,而LINQ …

    C# 2023年6月1日
    00
  • Vue前端如何实现与后端进行数据交互

    Vue前端与后端进行数据交互的方式主要有两种:使用axios库进行网络请求和使用WebSocket进行实时通信。下面我将对这两种方式进行详细的讲解。 一、使用axios库进行网络请求 1. 安装axios库 在Vue项目中使用axios库需要先安装该库。在终端中执行以下命令: npm install axios –save 2. 在Vue组件中使用axio…

    C# 2023年5月31日
    00
  • C#中List和数组之间转换的方法

    当我们在C#编程时,有时需要在List和数组之间进行转换。这里提供两种转换的方法: 方法一:使用List.ToArray()方法将List转为数组 我们可以使用List中的ToArray()方法来将List转为数组,如下所示: List<string> fruitsList = new List<string>{"apple…

    C# 2023年6月7日
    00
  • C#函数式编程中的惰性求值详解

    C#函数式编程中的惰性求值是一种重要的编程技巧,它指的是在执行程序时,只在需要的时候才计算数据或执行函数,而不是一开始就全部计算或执行。这种技巧可以提高程序的效率和性能,减少不必要的资源浪费。 惰性求值的实现方式主要有两种:生成器(yield)和延迟函数(Lazy)。其中,生成器是一种用于生成序列的特殊函数,通过调用yield语句来产生序列中的每个元素,延迟…

    C# 2023年5月15日
    00
  • asp.net SqlHelper数据访问层的使用

    作为网站的作者,关于asp.net SqlHelper数据访问层的使用,建议按照以下步骤进行: 步骤一:安装SqlHelper NuGet包 作为Sql Server数据访问层的封装,SqlHelper NuGet包能够帮助我们在asp.net应用程序中快速构建数据访问层。所以在开始本攻略前,最好先确认你已经安装了SqlHelper NuGet包。如果没有安…

    C# 2023年6月3日
    00
  • ASP.NET MVC实现单个图片上传、限制图片格式与大小并在服务端裁剪图片

    在ASP.NET MVC中实现单个图片上传、限制图片格式与大小并在服务端裁剪图片,可以按照以下步骤进行: 步骤1:创建MVC项目 在Visual Studio中创建一个新的ASP.NET MVC项目。 步骤2:上传图 在Views文件夹中创建一个名为Upload的文件夹,并在其中创建一个名为Index.cshtml的视图。在视图中添加以下HTML代码: @u…

    C# 2023年5月12日
    00
  • C#打开扬声器的实操方法和代码

    C#打开扬声器的实操方法和代码 在C#语言中,我们可以通过使用System.Media命名空间中的SoundPlayer类来播放音频文件。以下是打开扬声器的实操方法和代码。 例1:使用SoundPlayer播放本地音频文件 首先需要在你的项目中引入System.Media命名空间。 using System.Media; 接着,创建一个新的实例SoundPl…

    C# 2023年6月7日
    00
  • Java使用DateTimeFormatter格式化输入的日期时间

    在Java中,可以使用DateTimeFormatter类来格式化输入的日期时间。本文将提供使用DateTimeFormatter格式化日期时间的完整攻略,包括创建DateTimeFormatter对象、格式化日期时间、解析日期时间。同时,本文还将提供两个示例,演示如何使用DateTimeFormatter格式化日期时间。 创建DateTimeFormatt…

    C# 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部