孙卫琴的《精通JPA与Hibernate》读书笔记:对象-关系的映射概念
Java对象和关系数据库存在一些简单的映射关系,比如Customer类与CUSTOMERS表映射,一个Customer对象与CUSTOMERS表中的一条记录映射,Customer类的name属性与CUSTOMERS表的NAME字段映射。
但是,毕竟对象模型与数据库是按照不同的思路建立起来的,因此,在不少情况下,不存在一一对应的关系。比如Java对象之间可以双向关联,而数据库的表之间只有单向的参照关系,而且总是many方参照one方。表与表之间如果存在双向参照,需要通过连接表来建立对应关系。
补充:对象模型与数据库的建立思路到底有啥区别?对象模型需要提高代码的可重用,避免重复编码。而数据库需要减少数据的冗余,节省存储空间。
还有Java类有继承关系,关系数据库不存在继承关系。
JPA与Hibernate会通过各种各样的映射注解来建立对象对数据库中记录的映射。以前Hibernate3以下的版本流行用XML格式的映射文件来建立映射,现在这个方式不那么流行了。更为普遍的是用注解进行映射。
以下是用JPA映射注解对Customer类与CUSTOMERS表进行映射。
@Entity
@Table(name="CUSTOMERS") //Customer类和CUSTOMERS表映射
public class Customer implements java.io.Serializable {
@Id
@GeneratedValue(generator="increment")
@GenericGenerator(name="increment", strategy = "increment")
@Column(name="ID") //Customer类的id属性和CUSTOMERS表的ID字段映射
private Long id;
//Customer类的name属性和CUSTOMERS表的NAME字段映射
@Column(name="NAME")
private String name;
//Customer类的age属性和CUSTOMERS表的AGE字段映射
@Column(name="AGE")
private int age;
//Customer类与Order类一对多关联
@OneToMany(mappedBy="customer",
targetEntity=Order.class,
orphanRemoval=true,
cascade=CascadeType.ALL)
private Set<Order> orders = new HashSet<Order>();
……
}