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

运行:

相关推荐
陈天伟教授18 小时前
人工智能训练师认证教程(2)Python os入门教程
前端·数据库·python
Elastic 中国社区官方博客18 小时前
Elasticsearch:在分析过程中对数字进行标准化
大数据·数据库·elasticsearch·搜索引擎·全文检索
聪明努力的积极向上18 小时前
【MYSQL】字符串拼接和参数化sql语句区别
数据库·sql·mysql
代码or搬砖18 小时前
RBAC(权限认证)小例子
java·数据库·spring boot
神仙别闹19 小时前
基于QT(C++)实现学本科教务系统(URP系统)
数据库·c++·qt
2301_7683502319 小时前
MySQL为什么选择InnoDB作为存储引擎
java·数据库·mysql
上海蓝色星球19 小时前
迈向智慧电网新纪元:上海蓝色星球数字孪生变电主子站系统
运维·数据库
是大芒果19 小时前
数据库表设计
数据库
哥哥还在IT中19 小时前
MySQL order by 如何优化
数据库·mysql
积跬步,慕至千里19 小时前
postgre数据库大批量快速导出方法总结
数据库·postgres