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等方法进行数据过滤,同时可以对依赖实体进行排序等操作。

运行:

相关推荐
while(1){yan}8 小时前
Spring事务
java·数据库·spring boot·后端·java-ee·mybatis
盛世宏博北京9 小时前
高效环境管控:楼宇机房以太网温湿度精准监测系统方案
开发语言·数据库·php·以太网温湿度变送器
运维行者_9 小时前
2026 技术升级,OpManager 新增 AI 网络拓扑与带宽预测功能
运维·网络·数据库·人工智能·安全·web安全·自动化
gfdhy9 小时前
【C++实战】多态版商品库存管理系统:从设计到实现,吃透面向对象核心
开发语言·数据库·c++·microsoft·毕业设计·毕设
Elastic 中国社区官方博客9 小时前
Elasticsearch:上下文工程 vs. 提示词工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
小唐同学爱学习9 小时前
如何解决海量数据存储
java·数据库·spring boot·mysql
wWYy.10 小时前
详解redis(15):缓存雪崩
数据库·redis·缓存
zzcufo10 小时前
多邻国第五阶段第13部分
java·开发语言·数据库
这周也會开心10 小时前
Redis相关知识点
数据库·redis·缓存
小白爱运维10 小时前
MySQL升级8.0.44后登录报错-系统表不支持'MyISAM'存储引擎
数据库·mysql