介绍

在之前的 Entity Framework 快速上手介绍 之中,两个实体之间只是简单的一对一关系,而在实际的应用场景中,还会出现多对多关系,同时还有可能会出现多对多关系还附带有其他字段的情况。

下面以几个例子,对表间多对多关系的类表示加以更加详细地描述。虽然两个场景举例是使用的 C# 及 Entity Framework(Model First) 框架自动生成数据库、实体类。但这种设计方法,并不只是在使用 ORM 框架时需要,事实上,它是 POCO 及简单 Java 类(POJO)的设计原则之一。

场景实例

场景一

在考虑多对多关系还附带有字段的情况之前,让我们先看一下,多对多关系但不附带额外字段的情况下,实体类代码的表示。

此处使用 Entity Framework(Model First),快速将 model diagram 转为数据库中的表及实体类。

假设的场景是学生选课,一名学生可以选多门课,一门课也可以被多个学生选择。E-R 图如下所示:
平面设计培训,网页设计培训,美工培训,游戏开发,动画培训

对应自动生成的数据库如下:

平面设计培训,网页设计培训,美工培训,游戏开发,动画培训

  • StudentSet
    平面设计培训,网页设计培训,美工培训,游戏开发,动画培训

  • CourseSet
    平面设计培训,网页设计培训,美工培训,游戏开发,动画培训

  • CourseRegistrationSet
    平面设计培训,网页设计培训,美工培训,游戏开发,动画培训

    • 其中 Course_Id 与 Students_Id(注:此处词尾(s)负数的原因参见上面 E-R 图中右边的 Properties 中 End1 Navigation Property 的设置)分别以另外两张数据表的 Id 主键作为外键。

    • 同时 Course_Id与 Students_Id 两者联合做 CourseRegistrationSet 表的主键。

对应自动生成实体类的代码如下: