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

news2024/12/25 0:28:43

一、导航属性数据加载

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()时指定数据过滤。否则它将会加载整个辽宁省的数据。
2. 在调用Include()方法时,可以使用Where等方法进行数据过滤,同时可以对依赖实体进行排序等操作。
在这里插入图片描述

运行:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2257684.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【工具变量】上市公司企业过度负债数据(2000-2022年)

一、计算方式:参考C刊《投资研究》汪昌云(2022)老师的研究,将实际负债率与 Tobit 回归得到的目标负债率之差认定为过度负债率,该种方式认为目标负债率的驱动因素包括公司特征与行业因素,较为全面&#xff0…

分布式数据库中间件-Sharding-JDBC

文章目录 Sharding-JDBCSharding-JDBC介绍Sharding-JDBC的作用什么是分库分表分库分表的方式分库分表带来的问题事务一致性问题跨节点关联查询跨节点分页、排序函数主键重复 Sharding-JDBC 入门(水平分表)需求说明环境搭建编写代码流程分析其他配置方式概…

FPGA 16 ,Verilog中的位宽:深入理解与应用

目录 前言 一. 位宽的基本概念 二. 位宽的定义方法 1. 使用向量变量定义位宽 ① 向量类型及位宽指定 ② 位宽范围及位索引含义 ③ 存储数据与字节数据 2. 使用常量参数定义位宽 3. 使用宏定义位宽 4. 使用[:][-:]操作符定义位宽 1. 详细解释 : 操作符 -: 操作符 …

HTML:表格重点

用表格就用table caption为该表上部信息,用来说明表的作用 thead为表头主要信息,效果加粗 tbody为表格中的主体内容 tr是 table row 表格的行 td是table data th是table heading表格标题 ,一般表格第一行的数据都是table heading

hbuilder 本地插件配置

插件存放路径,项目根目录nativeplugins下,没有就新建。 aar文件存放路径\nativeplugins\pda-module\android package.json存放路径\nativeplugins\module\ 配置package.json文件 { "name": "本地插件", "id": &quo…

大模型应用的数字能源数据集

除了尚须时日的量子计算解决算力效率和能源问题,以及正在路上的超越transformer的全新模型架构外,无疑是“数据集”,准确讲是“高质量大规模多样性的数据集”。数据集是大模型发展的核心要素之一,是大计算的标的物,是实…

飞书解除复制,下载文件限制终极方案

1.通过移除copy 事件,可以复制文档内容,但是飞书表格增加了键盘按键事件,表格无法复制,下载 2.通过chrome插件,可以复制clould document converter 可以实现下载飞书文档,但是无法下载表格 而且无法识别自定…

Java面试题精选:设计模式(二)

1、装饰器模式与代理模式的区别 1)代理模式(Proxy Design Pattern ) 原始定义是:让你能够提供对象的替代品或其占位符。代理控制着对于原对象的访问,并允许将请求提交给对象前后进行一些处理。 代理模式的适用场景 功能增强 当需要对一个对…

自然语言处理:从入门到精通全指引

一、引言 自然语言处理(NLP)作为人工智能领域的关键分支,旨在让计算机理解、生成和处理人类语言,近年来取得了令人瞩目的成就,在智能客服、机器翻译、文本分析、语音助手等众多领域发挥着重要作用。从入门到精通自然语…

Typora 修改默认的高亮颜色

shift F12 参考 怎么给typora添加颜色?

(1)Quartus中如何在外设FLASH中固化jic文件

(1)在产生jic文件前,必须已经综合通过,生成了sof文件 (2)点击file-convert Programming Files... (3)文件类型选择jic文件,flsh型号设定为EPCS128 (4&#…

OpenAI2024-12D-3:Sora 发布,谁更胜一筹——Sora 与可灵的全面前瞻对比

藏了一年,终于OpenAI在12天活动的第三天,正式发布了其全新创意工具——Sora,这款工具凭借其强大的文本到视频生成能力和高度的创作自由度,迅速吸引了广大创作者的目光。与此同时,已经在视频创作领域有着成熟表现的可灵…

重生之我在异世界学智力题(4)

大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在CSDN这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 本文目录 引言渡河问题(1)问…

福州大学《2024年812自动控制原理真题》 (完整版)

本文内容,全部选自自动化考研联盟的:《福州大学812自控考研资料》的真题篇。后续会持续更新更多学校,更多年份的真题,记得关注哦~ 目录 2024年真题 Part1:2024年完整版真题 2024年真题

实现盘盈单自动化处理:吉客云与金蝶云星空数据对接

盘盈单103v2对接其他入库:吉客云数据集成到金蝶云星空 在企业信息化管理中,数据的高效流转和准确性至关重要。本文将分享一个实际案例,展示如何通过轻易云数据集成平台,将吉客云的数据无缝对接到金蝶云星空,实现盘盈单…

Meta Llama 3.3 70B:性能卓越且成本效益的新选择

Meta Llama 3.3 70B:性能卓越且成本效益的新选择 引言 在人工智能领域,大型语言模型一直是研究和应用的热点。Meta公司最近发布了其最新的Llama系列模型——Llama 3.3 70B,这是一个具有70亿参数的生成式AI模型,它在性能上与4050…

【优选算法 前缀和】前缀和算法模板详解:一维前缀 & 与二维前缀和

一维前缀和 题目解析 算法原理 解法一:暴力解法 简单模拟,读完题意有 q 次询问,给哪两个数,就求哪段区间的和并且返回,这样的做法,时间复杂度为O(N*q),这个时间复杂度会超时&#xf…

yarn : 无法加载文件 C:\Users\L\AppData\Roaming\npm\yarn.ps1,因为在此系统上禁

关于执行安装yarn命令后执行yarn -v报错: 先确认执行安装yarn命令是否有误 # 安装yarn npm install yarn -g 终端输入set-ExecutionPolicy RemoteSigned 当然如果yarn -v仍然执行失败,考虑使用管理员方式运行IDEA, 注:如上操作…

设计模式——单例模式和工厂模式

单例模式:一个类只创建一个类对象(节省内存减少类对象数量,一个类对象多次重复使用) 格式: class a: pass ba() z1b z2b #z1和z2为同一个类对象 工厂模式:(大批量创建具体的类对象,统一类对象入口便于维护&#xf…

UVM之寄存器模型生成

1.采用python脚本生成寄存器模型 首先用excel表格做好寄存器描述 然后编写脚本生成.ralf文件 (1)首先通过openpyxl读取EXCEL表格, workbook openpyxl.load_workbook(reg.xlsx) # 返回一个workbook数据类型的值 (2&#xff…