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/archive/2023/04/29/17363553.html

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

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

相关文章

  • C# 生成高质量缩略图程序—终极算法

    C# 生成高质量缩略图程序—终极算法 在本篇攻略中,我们将介绍如何用C#编写一个生成高质量的缩略图程序,以及如何使用终极算法来提高缩略图的质量。 前置知识 在开始之前,假设您已经掌握了以下知识: C#基础语法 图像处理基础知识 Visual Studio编辑器的基本使用 步骤1:引入必要的命名空间 首先我们需要在代码中引入以下命名空间: using Syst…

    C# 2023年6月8日
    00
  • C#使用async和await实现异步编程

    下面是C#使用async和await实现异步编程的完整攻略。 什么是异步编程? 异步编程是指同时执行多个操作,而且不用等待当前操作完成再去执行下一个操作的编程方式。使用异步编程可以在所有操作都完成之前充分利用资源,提高性能和效率。 C#异步编程的实现方式 在C#中,异步编程可以使用async和await关键字实现。async关键字用于修饰方法,表明该方法是异…

    C# 2023年5月15日
    00
  • ASP.net Substitution 页面缓存而部分不缓存的实现方法

    ASP.NET Substitution 页面缓存是指在对于某些页面的内容经常变化的情况下,我们可以启用页面缓存,但仍然让部分内容保持实时刷新的功能。本篇攻略将会为大家介绍如何实现此功能。 使用 Substitution 控件 我们可以使用 Substitution 控件的方式来实现 ASP.NET Substitution 页面缓存而部分不缓存的功能,具体…

    C# 2023年6月3日
    00
  • C#与C++枚举的区别对比和使用案例

    C#与C++枚举的区别对比和使用案例 枚举在C#和C++的基本定义 C#和C++中的枚举都是一组具有相同数据类型的常量。枚举定义的基本语法如下: C#: enum 枚举名称 { 枚举常量1, 枚举常量2, … } C++: enum 枚举名称 { 枚举常量1, 枚举常量2, … }; 在定义枚举时,常量的默认值从0开始自动递增。也可以给特定的枚举常量…

    C# 2023年5月15日
    00
  • Kubernetes(K8S)基础知识

    Kubernetes(K8S)基础知识 Kubernetes是一种开源的容器编排平台,可以简化部署、扩展和管理容器化应用程序。在Kubernetes中,可以创建一个包含多个容器的集群,通过Kubernetes控制器自动对其进行维护和扩展。 基本概念 节点(Node):Kubernetes集群中的物理或虚拟机器,可以运行容器。 Pod:Kubernetes中的…

    C# 2023年5月31日
    00
  • 垃圾代码二三行 ASPX小马

    攻击者可以通过嵌入”垃圾代码”来在服务器上运行恶意代码,从而达到控制服务器的目的。其中,”垃圾代码二三行 ASPX小马”是一种常见的攻击手段,本文将对其进行详细讲解。 什么是”垃圾代码二三行 ASPX小马” “垃圾代码二三行 ASPX小马”是指攻击者将一小段ASP.NET代码嵌入到页面中,通过这段代码来加载运行ASPX小马,从而达到控制服务器的目的。 攻击步…

    C# 2023年5月31日
    00
  • C# Linq的SkipWhile()方法 – 跳过序列中的元素,直到某个元素不满足

    下面是关于 C# Linq 的 SkipWhile() 的完整攻略。 SkipWhile() 简介 SkipWhile() 方法是 C# Linq 中的一种用来过滤序列的方法,其参数为一个带有一个参数和一个返回bool类型的委托,该委托定义了决定跳过哪些元素的方法。SkipWhile() 方法会跳过序列中开头符合条件的元素,直到遇到第一个不符合条件的元素为止…

    C# 2023年4月19日
    00
  • C#利用Random得随机数求均值、方差、正态分布的方法

    生成指定数量的随机数 首先需要生成指定数量的随机数,C#中使用Random类可以很方便地实现这个功能。下面是一个生成100个随机数的示例代码: int n = 100; double[] nums = new double[n]; Random rand = new Random(); for (int i = 0; i < n; i++) { num…

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