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日

相关文章

  • 记录.Net部署Docker-v指令使用

    记录Docker的-v指令使用 前言 之前我浅学了一下docker,方便部署.net项目(部署的是打包之后的项目) dockerfile文件如下: FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base WORKDIR /app EXPOSE 5031 EXPOSE 7031 FROM mcr.microsoft.c…

    C# 2023年4月25日
    00
  • .NET Core API之格式化输出对象OutputFormatter

    下面是详细的“.NET Core API之格式化输出对象OutputFormatter”的攻略。 1. OutputFormatter是什么? OutputFormatter是ASP.NET Core MVC框架中的一个组件,用于将响应数据对象序列化为HTTP响应内容。ASP.NET Core MVC框架中提供了多种不同格式的OutputFormatter,…

    C# 2023年6月3日
    00
  • C#调用C类型dll入参为struct的问题详解

    下面是“C#调用C类型dll入参为struct的问题详解”的完整攻略: 1. 为什么C#调用C类型dll入参为struct会有问题? 在C中,结构体的内存布局与内存对齐非常重要,C编译器默认会对结构体进行内存对齐操作,而C#的结构体内存布局与C的不同,所以我们在C#代码中调用C类型dll时,需要手动将C#结构体转换为C中内存对齐后的结构体,确保与C的结构体一…

    C# 2023年5月31日
    00
  • ASP.Net Core中的内存和GC机制

    ASP.Net Core是微软开发的基于跨平台的ASP.Net框架,其中内存和GC机制对于系统的性能和稳定性至关重要。 首先,ASP.Net Core的内存管理基于CLR(Common Language Runtime),并且实现了.NET Core所提供的垃圾回收机制。垃圾回收机制是自动管理内存的机制,不需要手动释放内存,自动检测和回收无用对象占用的内存。…

    C# 2023年6月3日
    00
  • 详解.NET Core 3.0 里新的JSON API

    在本攻略中,我们将详细讲解.NET Core 3.0中新的JSON API,并提供两个示例说明。 安装Microsoft.AspNetCore.Mvc.NewtonsoftJson:首先,我们需要安装Microsoft.AspNetCore.Mvc.NewtonsoftJson NuGet包。我们可以使用Visual Studio的Get包管理器来安装Mic…

    C# 2023年5月16日
    00
  • C#队列的简单使用

    C#队列的简单使用 队列是计算机科学中经典的数据结构,它具有先进先出的特点,即先被放入队列的数据将会先被取出。在C#语言中,可以通过使用Queue类来操作队列。在本文中,我们将讲述如何使用C#队列,包括创建队列,添加元素,获取元素,以及判断队列是否为空等操作。 创建队列 在C#中,可以通过以下方式来声明和初始化一个队列: Queue<int> m…

    C# 2023年6月6日
    00
  • ASP.NET中application对象的使用介绍

    ASP.NET中的Application对象是在网站全局范围内保存的一个数据容器,可以通过Application对象在多个页面间传递数据。本文将介绍ASP.NET中Application对象的使用方法,包括创建并保存数据、访问数据、以及如何在多个页面之间传递数据等。 创建并保存数据 在ASP.NET网站中,可以通过以下代码创建一个Application对象以…

    C# 2023年5月31日
    00
  • jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例

    下面我将详细讲解如何使用jQuery+JSON+jPlayer实现QQ空间音乐查询功能的完整攻略。步骤如下: 一、了解所需技术及工具 jQuery:一款流行的JavaScript库,可以大大简化JavaScript编程。 jPlayer:一款基于jQuery的HTML5音频播放器插件,可以播放不同格式的音频文件。 JSON:JavaScript对象表示法,一…

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