ASP.NET Core8.0学习笔记(二十五)——EF Core Include导航数据加载之预加载与过滤

一、导航属性数据加载

1.在EF Core中可以使用导航属性来加载相关实体。

2.加载实体的三种方式:

(1)预先加载:直接在查询主体时就把对应的依赖实体查出来(作为初始查询的一部分)

(2)显式加载:使用代码指示稍后显式的从数据库中加载数据

(3)延迟加载:在访问导航属性时,以透明的方式加载关联数据

二、数据预加载

1.关联查询:直接使用导航属性就可以访问关联数据,但是不能直接以"."去调用导航属性的数据,否则会报错,如示例代码所示:

运行:

原因是这里的导航属性Post只是起到一个完成约定配置的作用,其本身在主体数据加载时并不会自动加载关联数据。

要通过导航属性来访问数据,需要在DbSet的Include()方法来加载子数据。Include()接收两种与导航属性相关的参数。第一种是要加载的导航属性名的字符串,第二种是直接通过Lambda表达式来进行加载:

Lambda:

属性字符串:

运行:

2.多层级数据访问:可以通过多次调用Include()方法实现深层数据加载,以省市县数据为例:

省:

市:

县区:

在程序中使用Include与ThenInclude来实现多层级的数据加载:

运行:

注意:使用Include加载数据只是指定在加载主体的时候把依赖实体一并带出来并赋值,返回的实体依旧是最开始指定的DbSet。例如上面返回的就还是Province省,但是省内的市级与县级数据也会被一并查询出来。

三、使用Include进行数据过滤

1.在使用Include进行数据加载时,默认会加载主体实体所包含的所有依赖实体。但是某些时候我们不需要查询出所有的依赖实体,而是只需要加载我们感兴趣的数据即可。

例如,在上面的省-市-县三级联动查询中,假如我只想查询辽宁省大连市的所有数据,那么就需要在调用Include()时指定数据过滤。否则它将会加载整个辽宁省的数据。

  1. 在调用Include()方法时,可以使用Where等方法进行数据过滤,同时可以对依赖实体进行排序等操作。

运行:

相关推荐
maqr_11018 分钟前
MySQL数据库迁移到云端如何保障安全_数据加密与SSL连接配置
jvm·数据库·python
u01091476023 分钟前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
weixin_3812881828 分钟前
MySQL中如何使用HEX函数转换十六进制_MySQL进制转换函数
jvm·数据库·python
Deitymoon36 分钟前
嵌入式数据库——SQLite基础
数据库·sqlite
YMatrix 官方技术社区37 分钟前
美国·硅谷|YMatrix 即将亮相 Postgres Conference 2026,前瞻 AI 时代的数据基座
数据库·数据仓库·postgresql·时序数据库·ymatrix
bKYP953cL39 分钟前
构建自己的AI编程助手:基于RAG的上下文感知实现方案
数据库·人工智能·ai编程
Bert.Cai40 分钟前
MySQL DML简介
数据库·mysql
maqr_1101 小时前
HTML怎么生成订单预览_HTML只读订单信息结构【操作】
jvm·数据库·python
忧郁的蛋~1 小时前
基于.NET的Windows窗体编程之WinForms数据表格
windows·.net
2301_803875611 小时前
如何通过phpMyAdmin给WordPress所有用户发送全站通知_系统表插入
jvm·数据库·python