多对多(many-to-many)

要表示多对多关系,必须创建第三个表,该表通常称为联接表,它将多对多关系划分为两个一对多关系。将这两个表的主键都插入到第三个表中。

多对多(many-to-many)

举例1:学生-课程

  • 学生信息表:一行代表一个学生的信息(学号、姓名、手机号码、班级、系别...)

  • 课程信息表:一行代表一个课程的信息(课程编号、授课老师、简介...)

  • 选课信息表:一个学生可以选多门课,一门课可以被多个学生选择

学号     课程编号  
1        1001
2        1001
1        1002

举例2:产品-订单

“订单”表和“产品”表有一种多对多的关系,这种关系是通过与“订单明细”表建立两个一对多关系来定义的。一个订单可以有多个产品,每个产品可以出现在多个订单中。

  • 产品表:“产品”表中的每条记录表示一个产品。

  • 订单表:“订单”表中的每条记录表示一个订单。

  • 订单明细表:每个产品可以与“订单”表中的多条记录对应,即出现在多个订单中。一个订单可以与“产品”表中的多条记录对应,即包含多个产品。

多对多(many-to-many)

  • 举例3:用户-角色

  • 多对多关系建表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。

多对多(many-to-many)

上一篇:数据库 表关系


下一篇:[转载]Many to Many Relationship with ABP and EF Core