数据库中表与表之间的关系
Hibernate框架基于ORM设计思想,它将关系型数据库中的表与我们Java中的类进行映射,一个对象就对应着表中的一条记录,而表中的字段对应着类中的属性。数据库中表与表之间存在着三种关系,也就是系统设计中的三种实体关系。下面我会进行简单阐述。
一对一
什么样的关系属于一对一呢?例如一个公司只能有一个注册地址,一个注册地址只能被一个公司注册。一对一关系的建表原则有两种:
- 唯一外键对应:在任意一方添加一个外键来描述对应关系。如下图所示:
或者
- 主键对应:一方的主键作为另一方的主键。如下图所示:
实体类的设计:
-
员工类:
public class Employee { // 其他属性... private Archives archives; }
-
档案类:
public class Archives { // 其他属性... private Employee employee; }
一对多(多对一)
什么样的关系属于一对多(或者多对一)呢?客户与订单之间的关系就是一对多(或者多对一)关系,还有,比方说:
- 一个部门可以对应多个员工,但一个员工只能属于某一个部门;
- 一个客户对应多个联系人,但一个联系人只能属于某一个客户。
一对多(或者多对一)关系的建表原则:在多的一方添加外键来描述关联关系。如下图所示:
实体类的设计:
-
客户类:
public class Customer { // 其他属性... private Set<Order> orders; }
-
订单类:
public class Order { // 其他属性... private Customer c; }
多对多
什么样的关系属于多对多呢?学生与老师之间的关系就是多对多的关系,还有,比方说:
- 一个学生可以选择多门课程,一门课程也可以被多个学生选择;
- 一个用户可以选择多个角色,一个角色也可以被多个用户选择。
多对多关系的建表原则:通过一张中间表来描述其对应关系。如下图所示:
实体类的设计:
-
学生类
public class Student { // 其他属性... private Set<Teacher> ts; }
-
老师类
public class Teacher { // 其他属性... private Set<Student> ss; }