在我们没有学习Hibernate的时候,当我们建立数据库的表时,首先是数据库建模E-R图,然后再通过实体模型来建立关系模型,再建立相应的数据库表。实体间存在三种关系,一对一,一对多(多对一),多对多。而现在我们要根据类来映射相应的表,那只能是通过类与类之间的关系加上映射文件来映射数据库的表。
学习UML建模时我们知道,类与类之间存在五种关系,继承,实现,关联,依赖,聚合/组合,在hibernate中实体类之间的关系也是如此,下图为Hibernate的映射分类。
当然以上的关系还可以细分,例如,基本类与集合均为单个类的映射,而关系,继承,组件的映射都是多个类之间的关系,而且继承也属于关系映射,父类与子类,一个父类可以被多个子类继承,一个子类可以继承多个父类。对于这5类映射关系是我们大家常见,容易理解的,并在我们的可接受范围内,故并没有贴上关系图,下面根据这5类关系逐一进行介绍。
下面简单介绍基本映射
对象:
关系表:
t_user
实体类:
- package com.bjpowernode.hibernate;
-
- import java.util.Date;
-
- public class User {
-
- private String id;
- private String name;
-
- public String getId() {
- return id;
- }
- public void setId(String id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
-
- }
User.hbm.xml
-
- <hibernate-mapping package="com.bjpowernode.hibernate">
- <!--
- 对象关系映射的开始:class元素表示类和数据库中的表的映射关系。
- name属性指定持久化类(或者接口)的Java全限定名;
- table属性指定要映射的对应的数据库表名,如果省略,则以name作为表名
- -->
-
- <class name="User" table="t_user">
- <!--
- 持久化类对象的对象标识符(OID)和表的主键的映射关联:
- name属性指定类中作为OID的属性名;
- column属性表中主键字段的名字;如果省略,则以name作为字段名
- -->
-
- <id name="id" column="id">
-
- <generator class="native" />
- </id>
- <!--
- 普通属性的映射:
- name属性:属性的名字,以小写字母开头;
- column属性:对应的数据库字段名.如果省略,则以name作为字段名
- type属性:指定Hibernate的映射类型、如果省略,则自动匹配
- -->
- <property name="name" column="user_name" type="string"/>
- </class>
-
- </hibernate-mapping>
总结:
Hibernate的本质就是对象关系映射(ObjectRelationalMapping),ORM实现了将对象数据保存到数据库中,以前我们对关系表进行操作,执行增删改查等任务,现在我们不再对关系表进行操作,而是直接对对象操作,使开发更对象化了。
其中hibernate中的ORM映射文件通常以.hbm.xml作为后缀。使用这个映射文件不仅易读,而且可以手工修改,便于我们程序的后期维护!