ASP.NET Core8.0学习笔记(二十一)——EFCore关系配置API

一、关系配置API概述

  1. 当我们需要指定一个字段作为外键,而这个外键又不符合以上四种约定时,就需要在IEntityTypeConfiguration实现类(对应的配置类)中使用Fluent API直接配置外键。
  2. 理论上可以通过API直接指定一个属性,然后再配置外键。但是由于使用API的情况下导航属性的名称可能无法符合默认约定。而在默认的约定中,除了自动生成外键以外,更重要的是可以通过引用或集合导航属性来指定两个实体之间是一对一还是一对多的关系。因此如要使用API,首先应该明确:
    (1) 使用哪两个实体中的哪两个属性作为导航属性
    (2)两个实体是一对一、一对多还是多对多(较少见)的关系
  3. 在EF Core的Fluent API中,可以通过HasXXX、WithXXX来手动管理实体之间的关系。详细如下

二、一对多关系配置

  1. 应用场景:一个文章对应多条评论(一对多关系)
  2. 两个类:文章实体类Article,评论实体类Comment。一篇文章对应多条评论。评论中的Arcticle对象指向所属文章。 文章就是"主体实体",属关系中的"父级",评论就是"依赖实体",属关系中的"子级"。
    主体实体Article:
csharp 复制代码
```csharp
public class Article
{
    public long Id {get;set;}
    public string Title {get;set;}
    public string Message {get;set;}
    public List<Comment> Comments {get;set;}
}

依赖实体Comment

csharp 复制代码
public class Comment
{
    public long Id {get;set;}
    public Article TargetArticle {get;set;}
    public string Message{get;set;}
}

这两个实体都没有符合默认约定的导航属性,因此必须要通过API进行手动配置。而对于关系的配置一定要体现出实体之间的联系,如一对一还是一对多。这两个实体很明显是一对多的关系。

3.关系配置API

(1)EF Core中实体之间关系配置的套路:

API名称:HasXXX()、WithXXX(),先Has后Many,HasXXX由主体实体指向依赖实体,参数为导航属性,WithXXX()由依赖实体指向主体实体,参数也是导航属性。

所以API的名称有:

一对多:HasOne()、WithMany();

一对一:HasOne()、WithOne();

多对多:HasMany()、WithMany();

注意:在必须先使用Has后使用With。在调用完这两个API后,可以继续调用HasForeignKey()来指定在依赖实体中使用哪一个字段来作为外键。

(2)在有了外键导航属性后,即使在Context中不写其中的一张表,在迁移另一张表时,EF也会根据这个导航将对应的表迁移进去。这个表叫做导航属性表。但是由于DbSet中没有对应字段,会导致无法操作这张表

关系配置可以在两个实体之间任意一端配置。配置时是对于整张表做配置。一般情况下我们将关系配置在"一"端,也可以配置在"多"端。示例代码如下,首先在"多"端,也就是在Comment下进行配置:

示例代码

配置后打开数据库,可以看到对应的外键关系:

接下来在"一"端,也就是在Article一端进行配置(注意执行该操作需要删除数据库重新创建,或者手动移除外键约束以及对应的Migration,也就是回退迁移,并撤回原先的关于外键的代码配置):

执行数据迁移:

三、一对一关系配置

1.先不考虑实际场景,假设文章与评论是一对一的关系,实体如下:

主体实体Article:

csharp 复制代码
```csharp
public class Article
{
     public long Id { get; set; }
     public string Title { get; set; }
     public string Message { get; set; }
     public Comment Comments { get; set; }
}

依赖实体Message:

csharp 复制代码
public class Comment
{
     public long Id { get; set; }
     public string Message { get; set; }; }
	 public int ArticleEntityFkId { get; set; }
	 public Article TargetArticle { get; set; }

}

直接迁移,会发现无法生成外键:

使用API进行配置:将依赖实体的ArticleEntityFkId配置为外键,关系为一对一:

数据迁移:

相关推荐
徐子元竟然被占了!!3 小时前
Linux-systemctl
linux·数据库·oracle
YJlio5 小时前
Active Directory 工具学习笔记(10.8):AdInsight——保存与导出(证据留存、共享与二次分析)
数据库·笔记·学习
suoyue_zhan5 小时前
GBase的管理监控平台GEM实践指南
数据库
哈哈老师啊5 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
小小8程序员6 小时前
Redis-10
数据库·redis·缓存
liuzhilongDBA6 小时前
从collation mismatch异常到其原理
数据库·version·glibc·postgres·collation
梁萌6 小时前
MySQL数据库分库分表介绍
数据库·mysql·shardingsphere·分库分表
占疏7 小时前
dify API访问工作流/聊天
开发语言·数据库·python
Cat God 0078 小时前
SQL使用及注意事项
数据库·sql·mysql