您的位置:首页 > 其它

表关系:一对多,多对多

2015-06-22 18:13 288 查看
一对多和多对一

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>();
}
/**
分析中,我们不难发现,科目和学生是多对多的关系。
简单说:一门学科给多个学生学习,一个学生学习多门学科。
*/


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

学生表



学科表



中间表



在数据库中,多对多的关系的体现形式,其实需要一张中间表来维护。

中间表来记录双方的主键值。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  表关系