表关系:一对多,多对多

一对多和多对一
java实体中的表现形式

public class ClassEntity {//班级的实体类
private String classId;
    private String className;
    private Set<StuEntity> stu=new HashSet<StuEntity>();//一个班级下面有多个学生(一对多)
//get,set方法省略
}


public class StuEntity {//学生的实体类
    private String stuId;
    private String stuName;
    private ClassEntity stuClass;   //多个学生,对应一个班级(多对一)

    //get,set方法省略/**
在我们分析的时候,很容易的就知道,班级和学生的关系,是一对多的关系。反过来说,学生和班级就是多对一。
简单说:一个班级下面有多个学生,多个学生对应着一个班级。
*/

看下数据库里面是怎么体现这种形式的:

学生的表:
这里写图片描述
班级的表:
这里写图片描述

多对多
Java中实体类的体现

//科目实体类
public class SubjectEntity {
    private String subjectId;
    private String subjectName;
    private Set<StudentEntity> students=new             HashSet<StudentEntity>();
}

//学生实体类
public class StudentEntity {
    private String studentId;
    private String studentName;
    private Set<SubjectEntity> subjects=new HashSet<SubjectEntity>();
    }
/**
分析中,我们不难发现,科目和学生是多对多的关系。
简单说:一门学科给多个学生学习,一个学生学习多门学科。
*/

看下数据库里面是怎么体现这种形式的:

学生表
这里写图片描述
学科表
这里写图片描述
中间表
这里写图片描述

在数据库中,多对多的关系的体现形式,其实需要一张中间表来维护。
中间表来记录双方的主键值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值