efcore性能调优

性能调优——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日

相关文章

  • .NET Core(.NET6)中gRPC使用实践

    下面是关于“.NET Core(.NET6)中gRPC使用实践”的完整攻略,包含两个示例。 1. 什么是gRPC gRPC是一种高性能、开源、通用的RPC框架,由Google开发。它使用Protocol Buffers作为接口定义语言(IDL),可以在多种语言中使用,包括C#、Java、Python等。gRPC支持双向流、流控制、消息压缩等特性,可以用于构建…

    C# 2023年5月15日
    00
  • C# 操作Excel代码总结

    下面就为您详细讲解“C# 操作Excel代码总结”的完整攻略。 一、前言 在日常开发中,Excel 是我们经常应用的工具。在 C# 中,操作 Excel 也是一个常见的需求。本文就通过两个示例,来总结一下 C# 中操作 Excel 的代码实现过程。 二、基本环境 在操作 Excel 的过程中,我们需要引入以下命名空间: using Microsoft.Off…

    C# 2023年6月7日
    00
  • ASP.NET 水晶报表打印功能实现代码

    ASP.NET 水晶报表打印功能实现,需要以下几个步骤: 在 Visual Studio 新建 ASP.NET Web 应用程序项目,并添加 Crystal Reports 报表文件。 在 Web.config 文件中添加以下代码,即配置 Crystal Reports: xml <configSections> <sectionGroup…

    C# 2023年5月31日
    00
  • Entity Framework Core 大小写敏感处理

      可以使用’StringComparison’吗? 在数据库查询操作中,不可避免去考虑字母大小写的问题,比如要在Movie表中查找“X-Men”这部电影,为了不区分字母大小写,按照Linq to memory的习惯,可能会写出如下代码: DbContext.DbSet<Movie>  .Where(item => string.Equal…

    C# 2023年4月19日
    00
  • 国产化之银河麒麟安装.netcore3.1的详细步骤(手动安装)

    国产化之银河麒麟安装.NET Core 3.1的详细步骤(手动安装) .NET Core是一个跨平台的开源框架,它可以帮助我们构建高性能的Web应用程序。本攻略将详细介绍如何在银河麒麟操作系统上手动安装.NET Core 3.1。 环境要求 在进行.NET Core 3.1的手动安装时,我们需要满足以下环境要求: 银河麒麟操作系统 管理员权限 下载.NET …

    C# 2023年5月17日
    00
  • ASP.NET Core程序发布到Linux生产环境详解

    ASP.NET Core程序发布到Linux生产环境详解 在本攻略中,我们将详细介绍如何将ASP.NET Core程序发布到Linux生产环境中。我们将介绍两种不同的发布方式,并提供两个示例说明。 准备工作 在将ASP.NET Core程序发布到Linux生产环境之前,需要进行以下准备工作: 安装Linux操作系统。 安装.Net Core运行时。 安装Ng…

    C# 2023年5月16日
    00
  • 一些.NET对多线程异常处理技巧分享

    一些.NET对多线程异常处理技巧分享 前言 在多线程编程过程中,异常处理通常是一个很容易被忽视的问题,它对程序的稳定性和可靠性有着关键的影响。本文将对多线程异常处理中所需要注意的问题进行讨论,并分享一些.NET对多线程异常处理技巧。 1. 对于多线程处理不可避免的异常 在多线程处理过程中,我们很难避免出现一些不可避免的异常,比如线程间互相通信的异常等。针对这…

    C# 2023年5月15日
    00
  • .NET6打包部署到Windows Service的全过程

    以下是.NET 6打包部署到Windows Service的全过程攻略: 1. 什么是Windows Service Windows Service是一种在后台运行的应用程序,它可以在Windows操作系统启动时动启动,并在系统运行时一直运行。Windows Service通常用于执行后台任务,例如监视文件夹、处理消息队列等。 2. 什么是.NET 6 .N…

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