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

运行:

相关推荐
Runing_WoNiu3 分钟前
Mysql与Ooracle 索引失效场景对比
数据库·mysql·oracle
beijingliushao13 分钟前
32-Hive SQL DML语法之查询数据
数据库·hive·sql
JIngJaneIL44 分钟前
专利服务系统平台|个人专利服务系统|基于java和小程序的专利服务系统设计与实现(源码+数据库+文档)
java·数据库·小程序·论文·毕设·专利服务系统平台
__风__1 小时前
windows 上编译PostgreSQL
数据库·postgresql
木木子99991 小时前
数据库范式
数据库
涛思数据(TDengine)2 小时前
通过最严时序标准,再登产业图谱榜首,TDengine 时序数据库在可信数据库大会荣获双荣誉
大数据·数据库·时序数据库·tdengine·涛思数据
涛思数据(TDengine)2 小时前
新客户 | TDengine 时序数据库是怎么在钢厂“撬动”PI 的?
大数据·运维·数据库·时序数据库·tdengine
程序员柳2 小时前
基于Flask + Vue3 的新闻数据分析平台源代码+数据库+使用说明,爬取今日头条新闻数据,采集与清洗、数据分析、建立数据模型、数据可视化
数据库·数据分析·flask
哈基米喜欢哈哈哈3 小时前
Uber的MySQL实践(一)——学习笔记
数据库·笔记·后端·mysql
编程研究坊3 小时前
Neo4j APOC插件安装教程
数据库·人工智能·python·neo4j