`

hibernate联合主键

 
阅读更多

在日常开发中,有时候会出现要求两个或以上字段联合做主键的表,就两个字段做主键为例,用户表的联合主键为firstname和lastname,商品表的联合主键为id和pid等等。而在hibernate中,也提供了composite-id节点,对复合主键进行支持和定义。

为了说的更加详细,我们这里先新建一个T_User表,其中的firstname和lastname为该表的联合主键:

Sql代码
  1. CREATETABLET_User(
  2. FIRSTNAMEvarchar2(10),
  3. LASTNAMEvarchar2(4),
  4. AGENUMBER(2),
  5. CONSTRAINTPK_TABPRIMARYKEY(FIRSTNAME,LASTNAME)--l设置联合主键
  6. );

那么基于该表的hibernate的映射文件为:<hibername-mapping>

Xml代码
  1. <classname="com.entity.TUser"table="T_user">
  2. <composite-id>
  3. <key-propertyname="lastname"column="lastname"type="string"/>
  4. <key-propertyname="firstname"column="firstname"type="string"/>
  5. </composite-id>
  6. <propertycolumn="age"name="age"type="integer"/>
  7. </class>
  8. /hibernate-mapping>

hibernate要求复合主键类实现equal和hashcode方法,以作为不同数据之间的识别标志,那么Tuser.java的代码则应该如下:public class Tuser implement Serializable{

Java代码
  1. privateIntegerage;
  2. privateStringfirstname;
  3. privateStringlastname;
  4. //getterandsetter略
  5. publicbooleanequals(Objectobj){
  6. if(!(objinstanceofTuser)){
  7. returnfalse;
  8. }
  9. Tusertuser=(Tuser)obj;
  10. returnnewEqualsBuilder().appendSuper(super.equals(obj)).append(this.lastname,tuser.lastname).append(this.firstname,tuser.firstname).isEquals();
  11. }
  12. publicinthashCode(){
  13. returnnewHashCodeBuilder(-528253723,-475504089).appendSuper(super.hashCode()).append(this.lastname).append(this.firstname).toHashCode();
  14. }
  15. }

上述的EqualBuilder和HashCodeBuilder均为apache commons lang组件包中的工具类。Tuser中包含了复合组件数据,本身也是“主键类”的角色,即实体标志(id),因此,对于Session.load()方法而言,我们可以将Tuser类对象本身作为查询条件(Serialzable id)进行检索:

Java代码
  1. Tuseruesr=newTuser();
  2. user.setFirstname("Cat");
  3. user.setLastname("Dog");
  4. //以user为标志识别对象,通过load方法加载
  5. user=(Tuser).session.load(Tuser.class,user);
  6. syso("Userageis"+uesr.getAge());

关于引入的新节点composite-id,该节点的具体内容为:

Java代码
  1. <composite-id
  2. name="propertyName"
  3. class="ClassName"
  4. mapped="true|false"
  5. access="field|property|ClassName"
  6. node="element-name|."
  7. >
  8. <key-propertyname="propertyName"type="typename"column="column_name"/>
  9. <key-many-to-onename="propertyNameclass="ClassName"column="column_name"/>
  10. ......
  11. </composite-id>
其中包含了key-many-to-one的节点,它是用于实现多对一关联,当然我们这里没有涉及到,如果大家感兴趣,可以自己去查阅下相关的资料。
分享到:
评论

相关推荐

    hibernate联合主键全攻略

    ### Hibernate联合主键详解 #### 1. 定义联合主键 在Hibernate中定义联合主键主要依赖于`&lt;composite-id&gt;`标签。如示例文件所示,`Users`类被设计为具有联合主键,该主键由`name`和`tel`两个字段组成。在`...

    Hibernate联合主键的例子

    在Java持久化框架Hibernate中,联合主键(Composite Key)是一种特殊的数据结构,用于标识数据库表中的一条记录。与单个字段作为主键不同,联合主键由两个或更多个字段共同组成,形成一个唯一的标识。在本教程中,...

    hibernate的联合主键怎么设置

    在 Hibernate 中,联合主键(Composite Key)是指由两个或多个属性共同构成的主键,这种主键在数据库设计中常见于需要多个字段唯一标识一条记录的情况。在 Hibernate 中设置联合主键通常需要以下几个步骤: 1. **...

    Hibernate注解映射联合主键

    在Java的持久化框架Hibernate中,联合主键(Composite Key)是一种特殊的数据模型设计,用于处理具有多个字段作为主键的实体。联合主键通常在数据表中的某些列共同决定了唯一标识的情况出现。在Hibernate中,有三种...

    java hibernate使用注解来定义联合主键

    在Java Hibernate框架中,联合主键(Composite Key)是指由两个或多个属性共同构成的主键,这在处理一些特定的数据模型时非常有用。本文将详细介绍如何使用Hibernate注解来定义联合主键。 首先,我们需要了解联合...

    hibernate复合主键配置和使用

    《Hibernate复合主键配置与使用详解》 在Java开发中,Hibernate作为一款强大的ORM框架,大大简化了数据库操作。然而,当我们面临复杂的数据表结构,尤其是涉及到复合主键时,如何在Hibernate中进行配置和使用就显得...

    hibernate复合主键映射

    复合主键映射 &lt;br&gt;通常将复合主键相关属性,单独抽取出来,建立一个独立的类 * 必须实现序列化接口 * 必须实现equals和hashcode方法 采用标签进行映射,其它属性采用正常映射

    Hibernate复合主键视频2

    请更名为 Hibernate复合主键.part2.rar

    hibernate复合主键的实例

    在某些情况下,单一字段无法唯一标识表中的记录,此时需要多个字段联合起来作为主键。例如,考虑一个学生选课表,可能包含"学生ID"和"课程ID",这两者结合才能唯一确定学生选修的特定课程。 三、Hibernate中复合...

    Hibernate教程08_关系映射之联合主键

    在Hibernate中,实现联合主键可以通过使用`@Embeddable`和`@EmbeddedId`注解。首先,我们需要创建一个包含所有主键字段的类,并使用`@Embeddable`标记。这个类通常会作为其他实体类的属性,用`@EmbeddedId`注解。...

    JPA注解实现联合主键

    ### JPA注解实现联合主键 在关系型数据库中,单个字段作为主键的情况较为常见,但在某些场景下,我们需要使用多个字段共同作为主键来唯一标识表中的每一条记录,这就是所谓的“联合主键”。而在Java持久化框架...

    Hibernate一对一单向外键关联 (联合主键annotation)

    本篇将详细讲解如何使用Hibernate进行一对一单向外键关联,并且该关联涉及到联合主键的注解配置。 首先,一对一关联可以分为两种类型:单向和双向。在单向一对一关联中,只有一个实体知道另一个实体的存在,而另一...

    SSH2+JSO与三表联合主外键

    同时,Hibernate的Criteria API或HQL(Hibernate Query Language)可以帮助进行复杂的数据库查询,包括涉及多表连接的查询,这些查询可能涉及到联合主键和外键的使用。 综上所述,SSH2+JSON的结合提供了强大的后端...

    Hibernate 系列教程 单向一对多

    为了提高性能,我们可以使用`fetch="join"`(XML映射)或`@Fetch(FetchMode.JOIN)`(注解)进行联合查询,一次性获取所有关联的数据。 理解并熟练掌握Hibernate的单向一对多关联,能够帮助开发者更高效地处理复杂的...

    Hibernate面试题专栏 - 最全的Hibernate面试题, Hibernate笔试题, Hibernate问题

    - 联合主键是多个字段共同构成的主键,可以通过@EmbeddedId和@Embeddable注解实现。 - 复合主键是自动生成的主键,通过@TableGenerator或@IdClass实现。 **8. 异常处理** - Hibernate提供了自己的异常体系,如...

    Hibernate实体关系映射

    Hibernate实体关系映射

    Hibernate笔记 马士兵

    第1课 课程内容 6 第2课 Hibernate UML图 6 第3课 风格 7 第4课 资源 7 第5课 环境准备 7 ...三、 联合主键 24 1、xml方式 24 2、annotation方式 27 第14课 Hibernate核心开发接口(重点) 29 ........

    hibernate 3.6 中文 chm

    在Hibernate中,这种继承关系也可以被映射到数据库,如单表继承、联合继承和表-per-hierarchy等策略。 12. **延迟加载(Lazy Loading)**:为了提高性能,Hibernate支持属性和关联的延迟加载,即只有在真正需要时才...

    Hibernate原理解析

    Hibernate支持多种关系映射,如一对一、一对多、多对一和多对多,包括集合映射、联合主键映射等,使得复杂的数据关系得以轻松管理。 10. **实体生命周期** Hibernate管理着对象的生命周期,包括初始化、持久化、...

Global site tag (gtag.js) - Google Analytics