【SSH 基础】浅谈Hibernate映射

22 篇文章 0 订阅

      在我们没有学习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作为后缀。使用这个映射文件不仅易读,而且可以手工修改,便于我们程序的后期维护!

 

下篇继续!




评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值