C# Entity Framework 中不同的数据的加载方式

news/2024/10/22 13:44:08/

延迟加载

延迟加载是指在访问导航属性时,Entity Framework 会自动查询数据库并加载相关数据。这种方式在我们需要访问导航属性时比较方便,因为我们无需手动加载相关数据,而且只会在需要时才会进行查询,从而减少了不必要的开销。但是,如果我们需要访问多个导航属性,就可能会产生 N+1 问题,即需要执行多次查询来获取相关数据,从而影响性能。

及早加载

及早加载是指在查询主实体时,同时加载其关联实体,以避免 N+1 问题。这种方式需要使用 Include 方法来指定需要加载的导航属性,可以通过链式调用来指定多个导航属性。及早加载可以提高查询性能,但是也会增加数据传输量,因为可能会一次性加载大量数据。

显式加载

显式加载是指在需要时手动加载导航属性,适用于在已经查询到主实体的情况下,需要加载其关联实体的场景。这种方式需要使用 Load 方法来加载导航属性,可以使用 Collection 方法或者 Reference 方法来指定需要加载的导航属性。显式加载可以提高查询性能,因为只会查询需要的数据,但是需要手动编写代码来实现。

首先 安装俩程序包

先下载项目中安装 Entity Framework NuGet 包和Microsoft.EntityFrameworkCore.InMemory包
,不连接数据库。
Microsoft.EntityFrameworkCore.InMemory

步骤一 创建结构

在这里插入图片描述

步骤二 创建两个实体类

public class Author
{public int Id { get; set; }public string Name { get; set; }public ICollection<Book> Books { get; set; }
}
public class Book
{public int Id { get; set; }public string Title { get; set; }public int AuthorId { get; set; }public Author Author { get; set; }
}

步骤三 创建数据库上下文类

创建数据库上下文类 LibraryContext,LibraryContext 继承DbContext类
DbContext 是 Entity Framework 核心 API 之一,它表示应用程序与数据库之间的会话和操作。通过继承 DbContext 类,我们可以创建一个自定义的数据库上下文类,并在该类中定义数据集合(DbSet)和其他相关信息,以便进行查询、插入、更新和删除数据等一系列操作。

 public class LibraryContext : DbContext{public DbSet<Author> Authors { get; set; }public DbSet<Book> Books { get; set; }protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){optionsBuilder.UseInMemoryDatabase("Library"); // 使用内存数据库//optionsBuilder.UseSqlServer("Data Source=(localdb)\\MSSQLLocalDB;Initial Catalog=Library;Integrated Security=True;");}}

步骤四 模拟数据的添加

 static void Main(string[] args){using (var context = new LibraryContext()){// 创建模拟数据var author1 = new Author { Id = 1, Name = "Author 1" };var author2 = new Author { Id = 2, Name = "Author 2" };var book1 = new Book { Id = 1, Title = "Book 1", AuthorId = 1, Author = author1 };var book2 = new Book { Id = 2, Title = "Book 2", AuthorId = 1, Author = author1 };var book3 = new Book { Id = 3, Title = "Book 3", AuthorId = 2, Author = author2 };// 将模拟数据添加到数据库context.Authors.AddRange(new List<Author> { author1, author2 });context.Books.AddRange(new List<Book> { book1, book2, book3 });context.SaveChanges();// 延迟加载var loadedAuthor = context.Authors.FirstOrDefault(a => a.Id == 1);var books = loadedAuthor.Books.ToList();Console.WriteLine($"Author Name: {loadedAuthor.Name}");foreach (var book in books){Console.WriteLine($"Book Title: {book.Title}");}// 及早加载var eagerLoadedAuthor = context.Authors.Include(a => a.Books).FirstOrDefault(a => a.Id == 2);var eagerLoadedBooks = eagerLoadedAuthor.Books.ToList();Console.WriteLine($"Author Name: {eagerLoadedAuthor.Name}");foreach (var book in eagerLoadedBooks){Console.WriteLine($"Book Title: {book.Title}");}// 显式加载var explicitLoadedAuthor = context.Authors.FirstOrDefault(a => a.Id == 1);context.Entry(explicitLoadedAuthor).Collection(a => a.Books).Load();Console.WriteLine($"Author Name: {explicitLoadedAuthor.Name}");foreach (var book in explicitLoadedAuthor.Books){Console.WriteLine($"Book Title: {book.Title}");}}Console.ReadLine();}

http://www.ppmy.cn/news/1295632.html

相关文章

SpikingJelly笔记之泊松编码

文章目录 前言一、泊松编码的原理二、生成符合泊松分布的脉冲序列三、SpikingJelly中的泊松编码四、Lena图像的泊松编码与还原1.原始图像2.图像编码3.图像还原 总结 前言 记录SpikingJelly中泊松编码的使用方法&#xff0c;对图像数据进行编码与还原 一、泊松编码的原理 基于…

PIG框架学习2——资源服务器的配置详解

一、前言 1、pig资源服务器的配置 Spring Security oauth2相关的依赖是在pigx-common-security模块中引入的&#xff0c;其他模块需要进行token鉴权的&#xff0c;需要在微服务中引入pigx-common-security模块的依赖&#xff0c;从而间接引入相关的Spring security oauth2依赖…

互联网分布式应用之SpringCloud

SpringCloud Java 是第一大编程语言和开发平台。它有助于企业降低成本、缩短开发周期、推动创新以及改善应用服务。如今全球有数百万开发人员运行着超过 51 亿个 Java 虚拟机&#xff0c;Java 仍是企业和开发人员的首选开发平台。 课程内容的介绍 1. 微服务项目介绍 2. Eure…

【Matplotlib】基础设置之图像处理05

图像基础 导入相应的包&#xff1a; import matplotlib.pyplot as plt import matplotlib.image as mpimg import numpy as np %matplotlib inline导入图像 我们首先导入上面的图像&#xff0c;注意 matplotlib 默认只支持 PNG 格式的图像&#xff0c;我们可以使用 mpimg.im…

MySQL中的开发基于Python的SQL工具类操作数据库简单示例

操作数据库封装SQL工具类的两种方式 为了更方便的实现基于连接池和pymysql 连接数据库&#xff0c;需开发一个sql工具类来让sql操作更简洁用两张方式来封装SQL工具类 1 &#xff09;单例模式 封装 db.py 工具类 import pymysql from dbutils.pooled_db import PooledDBclas…

【LeetCode739】每日温度

1、题目描述 【题目链接】 给定一个整数数组 temperatures &#xff0c;表示每天的温度&#xff0c;返回一个数组 answer &#xff0c;其中 answer[i] 是指对于第 i 天&#xff0c;下一个更高温度出现在几天后。如果气温在这之后都不会升高&#xff0c;请在该位置用 0 来代替。…

CodeWave智能开发平台--03--目标:应用创建--07供应商数据表格01

摘要 本文是网易数帆CodeWave智能开发平台系列的第09篇&#xff0c;主要介绍了基于CodeWave平台文档的新手入门进行学习&#xff0c;实现一个完整的应用&#xff0c;本文主要完成07供应商数据表格 CodeWave智能开发平台的09次接触 CodeWave参考资源 网易数帆CodeWave开发者…

【linux学习笔记】网络

目录 【linux学习笔记】网络检查、监测网络ping-向网络主机发送特殊数据包traceroute-跟踪网络数据包的传输路径netstat-检查网络设置及相关统计数据 【linux学习笔记】网络 检查、监测网络 ping-向网络主机发送特殊数据包 最基本的网络连接命令就是ping命令。ping命令会向指…