Hibernate中,各表映射文件...hbm.xml详解

Hibernate中,各表映射文件...hbm.xml详解

 
配置文件的基本结构如下:

Xml代码

       <?xml version="1.0" encoding='UTF-8'?>      

    <!DOCTYPE hibernate-mapping PUBLIC  

      "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  

        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  

         <hibernate-mapping package="包名">  

        <class name="类名" table="表名">  

                <id name="主键在java类中的字段名" column="对应表中字段" type="类型">  

                    <generator class="主键生成策略"/>  

         </id>  

       

              ……  

         </class>  

    </hibernate-mapping>   

 

1. 主键(id
Hibernate
的主键生成策略有如下几种:
1) assigned
主键由外部程序负责生成,在save() 之前指定。
2) hilo
通过hi/lo 算法实现的主键生成机制,需要额外的数据库表或字段提供高位值来源。
3) seqhilo
hilo 类似,通过hi/lo 算法实现的主键生成机制,需要数据库中的 Sequence,适用于支持 Sequence 的数据库,如Oracle
4) increment
主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候将此值加1作为主键。这种方式可能产生的问题是:不能在集群下使用。
5) identity
采用数据库提供的主键生成机制。如DB2SQL ServerMySQL 中的主键生成机制。
6) sequence
采用数据库提供的sequence 机制生成主键。如Oralce 中的Sequence
7) native
 Hibernate 根据使用的数据库自行判断采用 identityhilosequence 其中一种作为主键生成方式。
8) uuid.hex
 Hibernate 基于128  UUID 算法 生成16 进制数值(编码后以长度32 的字符串表示)作为主键。
9) uuid.string
uuid.hex 类似,只是生成的主键未进行编码(长度16),不能应用在 PostgreSQL 数据中。
10) foreign
使用另外一个相关联的对象的标识符作为主键。
主键配置举例如下:

Xml代码

1         <id name="id" column="id" type="java.lang.Integer">  

2                      <generator class="native"/>  

3         </id>  

另外还可以扩展 Hibernate 的类来做自己的主键生成策略,具体例子见: http://www.javaeye.com/topic/93391
2. 普通属性(property

<property name="accessname" column="accessName" type="java.lang.String" not-null="true" />  

 <property name="state" column="state" type="java.lang.Byte" not-null="true" />  

 <property name="description" column="description" type="java.lang.String" /> 

 一对多关系(<many-to-one…/><set…></set>

      
 一对多关系一般是用在一个表与另一个表存在外键关联的时候,例如用户表的组织id与组织表存在外键关联,则方为组织表,方为用户表,因为一个组织可以包含多个用户,而一个用户只能隶属于一个组织。

   
 对于存在一对多关系和多对一关系的双方,需要在…hbm.xml中进行相应配置,这时在方(例如:组织)需要在映射文件中添加<set…></set>元素,因为它包含多个方的对象,一般的格式如下:

Xml代码

1         <set name="java映射类中对应的属性" inverse="true" lazy="true">  

2           <key column="表中对应字段"/>  

3              <one-to-many class="多方的类"/>  

4         </set>  

5           

6         <!-- 示例--> 

7         <set name="userSet" inverse="true" lazy="true">  

8               <key column="orgId"/>  

9               <one-to-many class="User"/>  

10     </set>  

方(例如:用户)隶属于一个方对象,一般的格式如下:

Xml代码

11     <many-to-one name="java映射类中对应的属性" column="表中对应字段" class="类名" not-null="true" />  

12       

13     <!-- 示例--> 

14     <many-to-one name="org" column="orgId" class="Organization" not-null="true" />  

4. 一对一关系(<one-to-one…/>

一对一关系相对一对多关系来说比较少见,但也在某些情况下要用到,例如有一个用户的基本信息表(USER)和一个用户的密码表(PASSWD)就存在一对一的关系。下面来看一下一对一关系在Hibernate的配置。

Xml代码

15     <!-- 其中主表(eg. 用户的基本信息表)的配置 --> 

16       

17     <one-to-one name="主表对象中子表对象的属性名" class="子表对象的类名" cascade="save-update"/>  

18       

19     <one-to-one name="password" class="com.amigo.dao.pojo.Passwd" cascade="save-update"/>  

20       

21     <!-- 子表(eg. 用户的密码表)的配置 --> 

22       

23     <one-to-one name="子表对象中主表对象的属性名" class="主表对象的类名" constrained="true"/>  

24       

25     <one-to-one name="user" class="com.amigo.dao.pojo.User " constrained="true" />  

5. 多对多关系(<many-to-many…/>

在数据库设计时,一般将多对多关系转换为两个一对多(或多对一)关系,例如在基于角色的权限系统中,用户和角色存在的关系就是典型的多对多关系,即一个用户可以具有多个角色,而一个角色又可以为多个用户所有,一般在设计时,都会加一个用户与角色的关联表,该表与用户表以及角色表都存在外键关联。

在本小节中讲述的是没有分解的多对多关系在Hibernate中如何配置。设置格式如下:

Xml代码

26     <set name="java对象的属性名" table="表名" cascade="all" outer-join="false">    

27         <key column="表的对应字段"/>    

28         <many-to-many class="另一个表的对象类" column="另一个表的字段"/>    

29     </set>    

30       

31     <!-- t_user --> 

32     <set name="roleSet" table="t_user" cascade="all" outer-join="false">    

33         <key column="roleId"/>    

34         <many-to-many class="com.amigo.dao.pojo.Role" column="roleId"/>    

35     </set>    

36       

37     <!-- t_role --> 

38     <set name="userSet" table="t_role" cascade="all" outer-join="false">    

39         <key column="roleId"/>    

40         <many-to-many class="com.amigo.dao.pojo.User" column="roleId"/>    

41     </set>

6. 完整实例

在本小节中举一些.hbm.xml映射文件的例子,让开发人员对其有一个感性的认识。接下来讲述一个用户表(tbl_user)、用户与角色关联表(tbl_user_role)、角色表(tbl_role)以及组织表(tbl_organization)的例子。

1tbl_user

Xml代码

1         <?xml version="1.0" encoding='UTF-8'?>  

2           

3         <!DOCTYPE hibernate-mapping PUBLIC  

4                   "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  

5                "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  

6           

7         <hibernate-mapping package="com.amigo.dao.pojo">  

8             <class name="User" table="tbl_user">  

9               <id name="loginname" column="loginName" type="java.lang.String">  

10               <generator class="assigned"/>  

11          </id>  

12          <property name="name" column="name" type="java.lang.String" not-null="true" />  

13          <property name="password" column="password" type="java.lang.String" not-null="true"/>  

14          <property name="mobile" column="mobile" type="java.lang.String" />  

15          <property name="telephone" column="telephone" type="java.lang.String" />  

16          <property name="email" column="email" type="java.lang.String" />  

17          <property name="createtime" column="createTime" type="java.util.Date" not-null="true" />  

18          <property name="lastlogintime" column="lastLoginTime" type="java.util.Date" />  

19         <property name="logintimes" column="loginTimes" type="java.lang.Long" not-null="true"/>  

20          <property name="state" column="state" type="java.lang.Byte" not-null="true" />  

21         <property name="description" column="description" type="java.lang.String" />  

22         <many-to-one name="organization" column="orgId" class="Organization" not-null="true"/>  

23         <set name="userRoleSet" inverse="true" cascade="all-delete-orphan" lazy="true">  

24             <key column="loginName"/>  

25             <one-to-many class="UserRole"/>  

26         </set>  

27     </hibernate-mapping>   

转自:http://blog.sina.com.cn/s/blog_77eba18f0101ar9h.html

  • 灌水
  • 赞
  • 美好
  • 顶
  • 顶
  • 顶
  • 开心
  • 路过
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值