【Entity Framework】你知道如何处理无键实体吗

【Entity Framework】你知道如何处理无键实体吗

文章目录

  • 【Entity Framework】你知道如何处理无键实体吗
    • 一、概述
    • 二、定义无键实体类型
          • 数据注释
    • 三、无键实体类型特征
    • 四、无键实体使用场景
    • 五、无键实体使用场景
    • 六、无键使用示例
      • 6.1 定义一个简单的Blog和Post模型:
      • 6.2 定义一个简单数据库视图
      • 6.3 定义一个类来保存数据库视图的结果
      • 6.4 使用HasNoKey API在OnModelCreating中配置无键实体类型
      • 6.5 配置`DbContext`以包含`DbSet<T>`
      • 6.7 采用标准方式查询数据库视图
    • 七、总结

在这里插入图片描述

一、概述

Entity Framework 除了常规实体类型外,EF Core模型还可以包含无键实体类型,可用于对不包含键值的数据执行数据库查询。

二、定义无键实体类型

可按如下定义无键实体类型:

  • 数据注释
[Keyless]
public class BlogPostsCount
{public string BlogName{get;set;}public int PostCount{get;set;}
}
  • Fluent API
protected override void OnModelCreating(ModelBuilder modelBuilder)
{modelBuilder.Entity<BlogPostsCount>().HasNoKey();
}

三、无键实体类型特征

无键实体类型支持与常规实体类型相同的多个映射功能,例如继承映射和导航属性。在关系存储上,它们可以通过Fluent API方法或数据注释来配置目标数据库对象和列。

但是,它们不同于常规实体类型,因为他们:

  • 不能定义键

  • 永远不会对DbContext中的更改进行跟踪,因此不会对数据库进行插入,更新或删除这些操作

  • 绝不会被约定发现

  • 仅支持导航映射功能的子集,具体如下:

    • 它们永远不能充当关系的主体端
    • 它们可能没有指向从属实体的导航
    • 它们只能包含指向常规实体的引用导航属性
    • 实体不能包含无键实体类型的导航属性
  • 需要配置 [Keyless] 数据注释或 .HasNoKey() 方法调用

  • 可以映射到定义查询。 定义查询是在模型中声明的查询,它充当无键实体类型的数据源

  • 可以具有层次结构,但必须映射为 TPH

  • 不能使用表拆分或实体拆分

四、无键实体使用场景

无键实体类型的一些主要使用场景包括:

  • 充当SQL查询的返回类型
  • 映射到不包含主键的数据库视图
  • 映射到未定义主键的表
  • 映射到模型中定义的查询

五、无键实体使用场景

可以使用 ToTableToView Fluent API 将无键实体类型映射到数据库对象。 从 EF Core 的角度来看,此方法中指定的数据库对象是一个视图,这意味着它将被视为只读查询源,并且不能作为更新、插入或删除操作的目标。 但是,这并不意味着数据库对象实际上必须是数据库视图。 它也可以是将被视为只读的数据库表。 相反,对于常规实体类型,EF Core 假设 ToTable 方法中指定的数据库对象可以作为表,这意味着它可用作查询源,但也可作为更新、删除和插入操作的目标。 事实上,可以在 ToTable 中指定数据库视图的名称,只要该视图配置为可在数据库上更新,一切都应能正常运行。

六、无键使用示例

6.1 定义一个简单的Blog和Post模型:

public class Blog
{public int BlogId { get; set; }public string Name { get; set; }public string Url { get; set; }public ICollection<Post> Posts { get; set; }
}public class Post
{public int PostId { get; set; }public string Title { get; set; }public string Content { get; set; }public int BlogId { get; set; }
}

6.2 定义一个简单数据库视图

db.Database.ExecuteSqlRaw(@"CREATE VIEW View_BlogPostCounts ASSELECT b.Name, Count(p.PostId) as PostCountFROM Blogs bJOIN Posts p on p.BlogId = b.BlogIdGROUP BY b.Name");

6.3 定义一个类来保存数据库视图的结果

public class BlogPostsCount
{public string BlogName { get; set; }public int PostCount { get; set; }
}

6.4 使用HasNoKey API在OnModelCreating中配置无键实体类型

protected override void OnModelCreating(ModelBuilder modelBuilder)
{modelBuilder.Entity<BlogPostsCount>(eb =>{eb.HasNoKey();eb.ToView("View_BlogPostCounts");eb.Property(v => v.BlogName).HasColumnName("Name");});
}

6.5 配置DbContext以包含DbSet<T>

public DbSet<BlogPostsCount> BlogPostCounts { get; set; }

6.7 采用标准方式查询数据库视图

var postCounts = db.BlogPostCounts.ToList();
foreach (var postCount in postCounts)
{Console.WriteLine($"{postCount.BlogName} has {postCount.PostCount} posts.");Console.WriteLine();
}

七、总结

无键主要应用在SQL、视图、存储过程的查询,在制作报表时,应用比较多。

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

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

相关文章

高分二号卫星(GF-2):中国遥感科技的新高度

​高分二号卫星&#xff08;GF-2&#xff09;是中国在高分辨率地球观测领域的重要成就&#xff0c;其引入了先进的成像技术和灵活的数据获取模式&#xff0c;为地球资源监测、环境保护、城市规划等领域提供了强大的数据支持。本文将深入介绍高分二号卫星的技术特点、成像能力以…

【华为OD机试】执行任务赚积分【C卷|100分】

题目描述 现有N个任务需要处理&#xff0c;同一时间只能处理一个任务&#xff0c;处理每个任务所需要的时间固定为1。 每个任务都有最晚处理时间限制和积分值&#xff0c;在最晚处理时间点之前处理完成任务才可获得对应的积分奖励。 可用于处理任务的时间有限&#xff0c;请问在…

10.Vue2.x条件渲染—v-if、v-show

文章目录 条件渲染—v-if、v-show 条件渲染—v-if、v-show <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><title>条件渲染</title><script type"text/javascript" src"../js/vue…

Day 27 39. 组合总和 40.组合总和II 131.分割回文串

组合总和 给定一个无重复元素的数组 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的数字可以无限制重复被选取。 说明&#xff1a; 所有数字&#xff08;包括 target&#xff09;都是正整数。解集不能…

BatchNorm算法详解

BatchNorm算法详解 1 BatchNorm原理 BatchNorm通过对输入的每个mini-batch的数据进行标准化&#xff0c;使得网络的输入分布更加稳定。 在训练过程中&#xff0c;每轮迭代网络层的输入数据分布变化很大的话&#xff0c;使得数据抖动很大&#xff0c;导致权重变化也会很大&am…

自定义类型: 结构体 (详解)

本文索引 一. 结构体类型的声明1. 结构体的声明和初始化2. 结构体的特殊声明3. 结构体的自引用 二. 结构体内存对齐1. 对齐规则2. 为啥存在对齐?3. 修改默认对齐值 三. 结构体传参四. 结构体实现位段1. 什么是位段?2. 位段的内存分配3. 位段的应用4. 位段的注意事项 ​ 前言:…

二维相位解包理论算法和软件【全文翻译- 加权最小二乘相位解包裹-PCG(5.4)】

5.4 加权最小二乘相位 与路径跟踪法不同,最小二乘法不直接处理残差问题,因为它们是通过对残差进行积分以最小化梯度差来求解的。另一方面,加权最小二乘法使用预先确定的权重(如质量图)来避免通过残差积分。选择权重的目的是以某种方式适应残差,隔离低信噪比区域,或对所…

什么是上位机?入门指南

什么是上位机&#xff1f; 上位机&#xff08;SCADA&#xff0c;Supervisory Control and Data Acquisition&#xff09;是一种软件系统&#xff0c;用于监控和控制工业过程中的设备。它通常与传感器、执行器和其他自动化设备一起工作&#xff0c;以实时地监视过程状态、收集数…

【精读文献】Scientific data|2017-2021年中国10米玉米农田变化制图

论文名称&#xff1a;Mapping annual 10-m maize cropland changes in China during 2017–2021 第一作者及通讯作者&#xff1a;Xingang Li, Ying Qu 第一作者单位及通讯作者单位&#xff1a;北京师范大学地理学部 文章发表期刊&#xff1a;《Scientific data》&#xff08…

Angular 嵌套表单

1.假设我有一个 “添加用户“ 的需求&#xff0c;在用户的信息中&#xff0c;联系方式分为邮箱和手机号&#xff0c;这两个联系方式就可以作为一个嵌套的内部的表单。下面是实现方式&#xff1a; <form [formGroup]"userForm"> <input type"text"…

Token2049主办方遭遇假门票风波,韩国罗马基金会Charles Lee损失50万美元

加密货币——遍地黄金&#xff1f;还是遍地陷阱&#xff1f; 尽管伊朗空袭以色列导致中东局势愈发紧张&#xff0c;但加密社区对当地市场的热情丝毫没有受到影响&#xff0c;不出意外的话&#xff0c;Token 2049这场全球最受瞩目的加密货币盛会将于4月18至19日在迪拜如期举行&…

Buck变换电路

Buck变换电路 Buck变换电路是最基本的DC/DC拓扑电路&#xff0c;属于非隔离型直流变换器&#xff0c;其输出电压小于输入电压。Buck变换电路具有效率高、输出稳定、控制简单和成本低的优点&#xff0c;广泛应用于稳压电源、光伏发电、LED驱动和能量回收系统。 电路原理 Buck变…

PyCharm 2024.1 发布:全面升级,助力高效编程!

PyCharm 2024.1 发布&#xff1a;全面升级&#xff0c;助力高效编程&#xff01; 文章目录 PyCharm 2024.1 发布&#xff1a;全面升级&#xff0c;助力高效编程&#xff01;摘要引言 Hugging Face&#xff1a;模型和数据集的快速文档预览针对 JavaScript 和 TypeScript 的全行代…

力扣101. 对称二叉树(java)

思路&#xff1a; 一、验证 左右子树是否可翻转对称的&#xff1f; 二、分析左右子树情况&#xff1a; 1&#xff09;左右都也空 对称 2&#xff09;左右有一个为空 不对称 3&#xff09;左右都不为空&#xff0c;但数字不同 不对称 4&#xff09;左右都不为空&#xff0c;且数…

C++从入门到精通——类和对象(下篇)

1. 再谈构造函数 1.1 构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值。 class Date { public:Date(int year, int month, int day){_year year;_month month;_day day;} private:int _year;int _mont…

实验一: 分析ARP解析过程

1.实验环境 主机A和主机B连接到交换机&#xff0c;并与一台路由器互连 2.需求描述 主机A和主机B连接到交换机&#xff0c;并与一台路由器互连主机A和主机B设置为同一网段&#xff0c;网关设置为路由接口地址查看ARP相关信息&#xff0c;熟悉在PC和Cisco设备上的常用命令 3.推…

[leetcode] 快乐数 E

:::details 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。 然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。 如果这个过程 结果为 1…

LeetCode 113—— 路径总和 II

阅读目录 1. 题目2. 解题思路3. 代码实现 1. 题目 2. 解题思路 看到树的问题一般我们先考虑一下是否能用递归来做。 假设 root 节点的值为 value&#xff0c;如果根节点的左子树有一个路径总和等于 targetSum - value&#xff0c;那么只需要将根节点的值插入到这个路径列表中…

全球首个AI女团Sorai.ai出道:定档4月19日北京电影节出道首秀

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

.net 6.0如何直接读取appsetting.json配置文件

现在有一个appsetting.json配置文件&#xff0c;里面有个setting下的url地址&#xff0c;需要读取&#xff0c;如下&#xff1a; {"Logging": {"LogLevel": {"Default": "Information","Microsoft": "Warning",&…