efcore性能调优

yizhihongxing

性能调优——EFCore调优

按下硬件、网络不提,我们单表从程序层面对系统的性能进行优化,翻来覆去无外乎三个方面

缓存
异步
sql
本片文章,我们针对.net core web项目的ef core框架进行性能优化。

1. EF Core框架已经本地缓存机制memorycache,所以我们访问一个接口,二次访问的性能相比首次会提升一大截

2.尽可能的通过主键查询

3.在进行字符串模糊查询时,分为三种情况

//StartsWith,相当于sql语句的like 'A%'
var result= ProductContext.Products.Where(p => p.ProductName.StartsWith("A")).ToList();

//EndsWith,相当于sql语句的like '%A'
var result= ProductContext.Products.Where(p => p.ProductName.EndsWith("A")).ToList();

//Contains,相当于sql语句的like '%A%'
var result= ProductContext.Products.Where(p => p.ProductName.Contains("A")).ToList();
其中的Contains()会导致索引失效,不建议使用

4.指定列查询。即字段查询、传输需要时间,字段越多,所需的时间就越多,所以我们可以指定我们所需的字段

ProductContext.Products.Select(p =>new { p.ProductId, p.ProductName})
对应的sql为:

select ProductId,ProductName
from Products
5.分页查询(常用于客户端查询)

int pageIndex = 1;
int pageSize = 10;

var result= ProductContext.Products
.Where(p => p.ProductName.StartsWith("A"))
.Take(pageSize) // 限制结果集数量。
.Skip((pageIndex - 1) * pageSize) // 数据的偏移量
.ToList();
6.一次性查询数据量较多时(如导出报表),借助缓冲区处理,即直接ToList()、ToArray()

ps:某些时候使用缓冲区而不是缓存,是因为缓冲区使用时会清空,而缓存不到过期时间不自动清空,某些场景下会浪费内存空间

//默认流式处理,遍历使用result时每次循环都会查询数据库
var result= ProductContext.Products.Where(p => p.ProductName.StartsWith("A"));

//缓冲区处理(一次性将数据查出,使用result时,直接从队列中取数据)
var result= ProductContext.Products.Where(p => p.ProductName.StartsWith("A")).ToList();
7.EFCore会对查询出来的数据进行缓存、跟踪。跟踪监控造成额外的空间浪费,但能方便更新数据,所以在不涉及修改的情况下(只查询时),我们可以用AsNoTracking()方法来手动关闭跟踪

var result= ProductContext.Products
.Where(p => p.ProductName.StartsWith("A"))
.AsNoTracking()
.ToList();
8.使用异步 ToListAsync()

—————————以上为单个表数据的efcore优化—————————

原文链接:https://blog.csdn.net/YangWeiKe/article/details/130351397

原文链接:https://www.cnblogs.com/wugh8726254/p/17363553.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:efcore性能调优 - Python技术站

(0)
上一篇 2023年5月5日
下一篇 2023年5月5日

相关文章

  • Qt之调用C#的动态库的解决方法

    下面是关于”Qt之调用C#的动态库的解决方法”的完整攻略。 问题描述 Qt是一种跨平台的C++应用程序开发框架,然而有时候需要使用到C#写的动态链接库,此时需要解决Qt调用C#的动态库的问题。 解决方案 Qt虽然没有直接支持调用C#的动态链接库的方法,但是可以通过C++/CLI嵌入C#代码的方式实现调用C#动态库的功能,具体步骤如下: 1. 创建C++/CL…

    C# 2023年5月15日
    00
  • ASP.NET C#中Application的用法教程

    下面是ASP.NET C#中Application的用法教程的完整攻略: 什么是 Application? 在 ASP.NET C# 中,Application 可以理解为全局变量,它在整个应用程序范围内都可用。Application 可以存储和访问应用程序的常用的数据,并在不同的页面和会话之间共享这些数据。 如何使用 Application? 在 C# 中…

    C# 2023年5月15日
    00
  • C#生成DLL文件的方法小结

    C#生成DLL文件的方法小结 什么是DLL文件 DLL,全称Dynamic Link Library,即“动态链接库”,是Windows操作系统中组成的程序代码库,我们常用的动态链接库文件后缀名为.dll。通过DLL文件,可以把一个或多个函数组成一个DLL文件,其他程序通过调用DLL文件中的函数来实现某些特定的功能。DLL文件一般分为静态链接库和动态链接库两…

    C# 2023年6月1日
    00
  • 在C#中捕获内存不足异常

    在C#中,当应用程序需要使用更多内存而系统没有足够的内存可用时,就会发生内存不足异常。在这种情况下,应用程序可以捕获此异常来处理或记录错误并采取必要的措施避免程序崩溃。下面是在C#中捕获内存不足异常的完整攻略: 1. 使用try-catch语句捕获内存不足异常 在C#中,使用try-catch语句捕获内存不足异常是一种常见的方法。下面是一个基本的示例: tr…

    C# 2023年5月15日
    00
  • EF Core基础入门教程

    EF Core是一个轻量级、可扩展的ORM框架,提供了一种使用C#代码进行数据库访问和操作的方式。在本篇文章中,我们将介绍EF Core的基础入门教程。 安装EF Core 首先,下载并安装.NET Core SDK。然后,可以使用以下命令安装EF Core: dotnet add package Microsoft.EntityFrameworkCore …

    C# 2023年6月3日
    00
  • asp.net 中将表单提交到另一页 Code-Behind(代码和html在不同的页面)

    要将表单提交到另一页Code-Behind中,需要执行以下步骤: 1. 设置HTML表单 在HTML页面中,设置表单的提交属性为“POST”,方法属性设置为“server”,并在表单中添加所需的输入元素。 <!DOCTYPE html> <html lang="en"> <head> <meta …

    C# 2023年5月31日
    00
  • C# Path.GetTempFileName()方法: 获取一个唯一的临时文件名

    Path.GetTempFileName()方法作用及使用方法 C#的Path.GetTempFileName()方法可以返回一个唯一的临时文件名,并创建该文件。此临时文件的路径和文件名是在指定目录(如:%temp%)中由系统自动生成的,以确保每次调用时都必须生成唯一的文件名。 使用方法 Path.GetTempFileName()方法的使用非常简单,只需直…

    C# 2023年4月19日
    00
  • C# Linq的Join()方法 – 将两个序列中的元素联接在一起

    C#中的Linq提供了Join()方法来实现两个数据源之间的连接。Join()方法接受四个参数,可以在连接过程中指定连接的条件以及返回的结果类型等信息。接下来,我将为您提供一个完整的攻略来详细讲解C# Linq的Join()方法。 Join()方法的基本语法 下面是Join()方法的基本语法: var result = from s in source1 j…

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