都有哪几种关系?

1vs多,多vs多

1. 概念or关系映射相关方法:

1) 基本套路:this.Has***(o=>o.AAA).With***() 当前这个表和AAA属性的表关系是Has定义,With定义AAA表和这个表的关系

BBBConfig{
//这是1vs多的关系,1个AAA钟包含多个BBB
public BBBConfig(){
//这个BBB有多少个A属性;从后读A钟有多少B
this.Has***(o=>o.A).With***();
}
} class AAA{
public long Id{get;set;}
} class BBB{
public long Id{get;set;}
public AAA A{get;set;}
}

2)  HasOptional() 有一个可选的(可以为空的)

3)  HasRequired() 有一个必须的(不能为空的)

4)  HasMany() 有很多的

5)  WithOptional() 可选的

6)  WithRequired() 必须的

7)  WithMany() 很多的

Eg:

在AAA实体中配置this.HasRequired(o=>o.BBB).WithMany();

表示在AAA中有且只有一个BBB,而在BBB中有对应多个AAA;

在AAA实体中配置this.HasRequired(o=>o.BBB).WithRequired();

表示在AAA中有且只有一个BBB,而在BBB中也只有一个对应的AAA

练习:

public class Class
{
public long Id { get; set; }
public string Name { get; set; }
//双向设计关系会让模型变的更难理解,同时可通过代码替代
// Class clz = ctx.Classes.First();
//var students =ctx.Students.Where(s => s.ClassId == clz.Id);
public virtual ICollection<Student> Students { get; set; } = new List<Student>();
} public class Student
{
public long Id { get; set; }
public string Name { get; set; }
public long ClassId { get; set; }
public virtual Class Class { get; set; }
public int Age { get; set; }
}

实体类

public class ClassConfig:EntityTypeConfiguration<Class>
{
public ClassConfig() {
ToTable("T_Classes");
}
}
public class StudentConfig:EntityTypeConfiguration<Student>
{
public StudentConfig() {
ToTable("T_Students");
}
}
public class TestContent:DbContext
{
public TestContent() : base("name=connStr")
{
Database.SetInitializer<TestContent>(null);
} protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Configurations.AddFromAssembly(Assembly.GetExecutingAssembly());
} public DbSet<Class> Classes { get; set; }
public DbSet<Student> Students { get; set; }
}
static void Main(string[] args)
{
using (TestContent ctx = new Tests.TestContent())
{
ctx.Database.Log = (sql) =>
{
Console.WriteLine(sql);
};
Class clz = new Tests.Class();
clz.Name = "一年一班";
ctx.Classes.Add(clz); Student s1 = new Tests.Student();
s1.Name = "小明";
s1.Class = clz;
s1.Age = ;
ctx.Students.Add(s1);
ctx.SaveChanges();
}
}

FluentAPI关系配置深入

1. 建议在多的一端进行配置,从数据库角度外键也是建在多的一端

public class StudentConfig:EntityTypeConfiguration<Student>
{
public StudentConfig() {
ToTable("T_Students");
//许多个学生只有一个班级,一个班级有需要个学生,外键是classId
HasRequired(e => e.Class).WithMany().HasForeignKey(e => e.ClassId);
}
//如果 ClassId 可空,那么就要写成 :
//this.HasOptional (s => s.Class).WithMany().HasForeignKey(s => s.ClassId)
}

2. 一对多的关系在一端配置就可以了,当然两边都配也不错。

3. 如果一张表中有两个指向另外一个表的外键怎么办?比如学生有“正常班级 Class”(不能空)和“小灶班级 XZClass”(可以空)两个班。如果用默认约定就会报错,怎么办?

this.HasRequired(s => s.Class).WithMany().HasForeignKey(s => s.ClassId);
this. HasOptional (s => s.XZClass).WithMany().HasForeignKey(s => s.XZClassId);

多VS多关系配置

class Student
{
public long Id { set; get; }
public string Name { get; set; }
public virtual ICollection<Teacher> Teachers { get; set; }=new List<Teacher>();
}
class Teacher
{
public long Id { set; get; }
public string Name { get; set; }
public virtual ICollection<Student> Students { get; set; }=new List< Student >();
}

实体对象

class StudentConfig : EntityTypeConfiguration<Student>
{
public StudentConfig()
{
ToTable("T_Students");
}
}
class TeacherConfig : EntityTypeConfiguration<Teacher>
{
public TeacherConfig()
{
ToTable("T_Teachers");
//多个老师对应多个学生,多个学生对应多个老师;map映射关系表,
//当前左键指的当前表
this.HasMany(e => e.Students).WithMany(e => e.Teachers)
.Map(m =>
m.ToTable("T_TeacherStudentRelations").MapLeftKey("TeacherId").MapRightKey("StudentId"));
}
}

这样不用中间表建实体(也可以为中间表建立一个实体,其实思路更清晰),就可以完

成多对多映射。当然如果中间关系表还想有其他字段,则要必须为中间表建立实体类。

FluentAPI关系映射配置的更多相关文章

  1. EF里一对一、一对多、多对多关系的配置和级联删除

    本章节开始了解EF的各种关系.如果你对EF里实体间的各种关系还不是很熟悉,可以看看我的思路,能帮你更快的理解. I.实体间一对一的关系 添加一个PersonPhoto类,表示用户照片类 /// < ...

  2. Entity Framework Code First关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  3. EF——一对一、一对多、多对多关系的配置和级联删除 04(转)

    EF里一对一.一对多.多对多关系的配置和级联删除   本章节开始了解EF的各种关系.如果你对EF里实体间的各种关系还不是很熟悉,可以看看我的思路,能帮你更快的理解. I.实体间一对一的关系 添加一个P ...

  4. Entity Framework Code First主外键关系映射约定

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  5. Entity Framework Code First关系映射约定【l转发】

    本篇随笔目录: 1.外键列名默认约定 2.一对多关系 3.一对一关系 4.多对多关系 5.一对多自反关系 6.多对多自反关系 在关系数据库中,不同表之间往往不是全部都单独存在,而是相互存在关联的.两个 ...

  6. EFCodeFirst关系映射约定

    EFCodeFirst关系映射约定 EFCodeFirst 关系映射约定 默认多重关系的一些约定规则: 1.一对多关系 两个类中分别包含一个引用和一个集合属性. 两个类中一个类包含另一个类的引用属性. ...

  7. MyBatis 关系映射XML配置

    关系映射 在我看来这些实体类就没啥太大关联关系,不就是一个sql语句解决的问题,直接多表查询就完事,程序将它设置关联就好 xml里面配置也是配置了sql语句,下面给出几个关系的小毛驴(xml) 一对多 ...

  8. $Django setting.py配置 ,GET、POST深入理解,三件套,orm对象关系映射简介

    1 django中app的概念: 大学:----------------- 项目  信息学院 ----------app01  物理学院-----------app02 ****强调***:创建的每一 ...

  9. Django---静态文件配置,post提交表单的csrf问题(日后细说),创建app子项目和分析其目录,ORM对象关系映射简介,Django操作orm(重点)

    Django---静态文件配置,post提交表单的csrf问题(日后细说),创建app子项目和分析其目录,ORM对象关系映射简介,Django操作orm(重点) 一丶Django的静态文件配置 #we ...

随机推荐

  1. 一系列令人敬畏的.NET核心库,工具,框架和软件

    内容 一般 框架,库和工具 API 应用框架 应用模板 身份验证和授权 Blockchain 博特 构建自动化 捆绑和缩小 高速缓存 CMS 代码分析和指标 压缩 编译器,管道工和语言 加密 数据库 ...

  2. vc++如何创建程序-析构函数01

    #include<iostream.h>class Point{public: int x; int y; Point() { x=0; y=0; }//构造函数是用来创建函数本身,那么, ...

  3. day22 包,相对/绝对路径

    目录 包 包被导入时发生的三件事 为什么要有包 相对路径 绝对路径 包 包是一个文件夹,也是一个模块,只是为了区分单个文件的模块,称之为包.因为单纯的文件夹无法作为模块,文件夹内的__init__.p ...

  4. 路飞学城Python-Day80

    36-模板语法之继承 Django模版引擎中最强大也是最复杂的部分就是模版继承了.模版继承可以让您创建一个基本的“骨架”模版,它包含您站点中的全部元素,并且可以定义能够被子模版覆盖的 blocks . ...

  5. centos7编译安装mysql5.6

    先安装如下依赖包: $ yum -y install make gcc-c++ cmake bison-devel  ncurses-devel 下载MySQL5.6.14安装包,https://pa ...

  6. springMVC常用注解的使用

    一.@ResponseBody注解的使用 1. @responseBody注解的作用是将controller的方法返回的对象通过适当的转换器,转换为指定的格式之后, 写入到response    对象 ...

  7. Python数据分析2------数据探索

    一.数据探索 数据探索的目的:及早发现数据的一些简单规律或特征 数据清洗的目的:留下可靠数据,避免脏数据的干扰. 两者没有严格的先后顺序,经常在一个阶段进行. 分为: (1)数据质量分析(跟数据清洗密 ...

  8. github下载报错:Permission denied (publickey). fatal: Could not read from remote repository.

    Permission denied (publickey). fatal: Could not read from remote repository. 博主在github上下载tiny face的的 ...

  9. 汇编-理解call,ret

    ; 有意思的东西,主函数调用子函数用汇编来理解 assume cs:codeseg codeseg segment start: main: call sub1 ; 调用子函数1, push IP1 ...

  10. Python GitHub上星星数量最多的项目

    GitHub上星星数量最多的项目 """ most_popular.py 查看GitHub上获得星星最多的项目都是用什么语言写的 """ i ...