日期:2014-05-16  浏览次数:20440 次

Hibernate映射解析——七种映射关系
        首先我们了解一个名词ORM,全称是(Object Relational Mapping),即对象关系映射。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现,这样开发人员就可以把对数据库的操作转化为对这些对象的操作。Hibernate正是实现了这种思想,达到了方便开发人员以面向对象的思想来实现对数据库的操作。       

        Hibernate在实现ORM功能的时候主要用到的文件有:映射类(*.java)、映射文件(*.hbm.xml)和数据库配置文件(*.properties/*.cfg.xml),它们各自的作用如下。

        映射类*.java:它是描述数据库表的结构,表中的字段在类中被描述成属性,将来就可以实现把表中的记录映射成为该类的对象了。

        映射文件(*.hbm.xml:它是指定数据库表和映射类之间的关系,包括映射类和数据库表的对应关系、表字段和类属性类型的对应关系以及表字段和类属性名称的对应关系等。

        数据库配置文件(*.properties/*.cfg.xml:它是指定与数据库连接时需要的连接信息,比如连接哪种数据库、登录数据库的用户名、登录密码以及连接字符串等。当然还可以把映射类的地址映射信息放在这里。

        接下来让我们就一起走进Hibernate的七种映射关系:

        1、        单向一对一关联映射(one-to-one):

        两个对象之间一对的关系,例如:Person(人)-IdCard(身份证)

        有两种策略可以实现一对一的关联映射:

               *主键关联:即让两个对象具有相同的主键值,以表明它们之间的一一对应的关系;数据库表不会有额外的字段来维护它们之间的关系,仅通过表的主键来关联。如下图:

            例子:单向一对一主键关联例子连接

               *唯一外键关联:外键关联,本来是用于多对一的配置,但是加上唯一的限制之后(采用<many-to-one>标签来映射,指定多的一端uniquetrue,这样就限制了多的一端的多重性为一),也可以用来表示一对一关联关系,其实它就是多对一的特殊情况。如下图:


        例子:单向一对一唯一外键关联例子连接

        注意:因为一对一的主键关联映射扩展性不好,当我们的需要发生改变想要将其变为一对多的时候变无法操作了,所以我们遇到一对一关联的时候经常会采用唯一外键关联来解决问题,而很少使用一对一主键关联。

        2、        单向多对一关联映射(many-to-one):

       多对一关联映射原理:在多的一端加入一个外键,指向一的一端,如下图:


       关键映射代码——在多的一端加入如下标签映射:      

          <many-to-one name="group" column="groupid"/>

       3、         单向一对多关联映射(one-to-many)

       一对多关联映射和多对一关联映射原理是一致的,都是在多的一端加入一个外键,指向一的一端。如下图(学生和班级):


       注意:它与多对一的区别是维护的关系不同

               *多对一维护的关系是:多指向一的关系,有了此关系,加载多的时候可以将一加载上来

               *一对多维护的关系是:一指向多的关系,有了此关系,在加载一的时候可以将多加载上来

       关键映射代码