|  | 本文参考《精通JPA与Hibernate:Java对象持久化技术详解》,作者:孙卫琴,清华大学出版社出版 
 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 Setorders = new HashSet();
 ……
 }
 | 
 
  
 
 
 程序猿的技术大观园:www.javathinker.net
 
 
 
 
 
 [这个贴子最后由 admin 在 2021-10-09 10:45:38 重新编辑]
 |  |