在我们没有学习Hibernate的时候,当我们建立数据库的表时,首先是数据库建模E-R图,然后再通过实体模型来建立关系模型,再建立相应的数据库表。实体间存在三种关系,一对一,一对多(多对一),多对多。而现在我们要根据类来映射相应的表,那只能是通过类与类之间的关系加上映射文件来映射数据库的表。
学习UML建模时我们知道,类与类之间存在五种关系,继承,实现,关联,依赖,聚合/组合,在hibernate中实体类之间的关系也是如此,下图为Hibernate的映射分类。
当然以上的关系还可以细分,例如,基本类与集合均为单个类的映射,而关系,继承,组件的映射都是多个类之间的关系,而且继承也属于关系映射,父类与子类,一个父类可以被多个子类继承,一个子类可以继承多个父类。对于这5类映射关系是我们大家常见,容易理解的,并在我们的可接受范围内,故并没有贴上关系图,下面根据这5类关系逐一进行介绍。
下面简单介绍基本映射
对象:
关系表:
t_user
id | name |
1 | 张三 |
实体类:
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">
<!-- 指定对象标识符生成器:class属性指定生成器的类别名 -->
<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作为后缀。使用这个映射文件不仅易读,而且可以手工修改,便于我们程序的后期维护!
下篇继续!