`
longxiaoyan
  • 浏览: 77513 次
  • 性别: Icon_minigender_1
  • 来自: 桂-京
社区版块
存档分类
最新评论

hibernate 多对多 中间表主键问题 及id生成方式

阅读更多
hibernate多对多中间表,一般都是两个外键,例如
用户表(user,主键:
userid.
角色表(role,主键:
roleid.
中间表字段为两个外键:useridroleid作为联合主键。

但是如果想在中间表加一个字段作为单独的主键,即设置一个字段id作为主键。并且数据库采用的是oracle数据库,主键不能自增。那么采用hibernate向中间表插数据的时候,就会出现问题,即主键id字段插入为空,会报错误。


由于oracle不支持自动编号,为解决以上错误,我们还得为oracle数据库创建一个SEQUENCE(序列)语句如
create sequence t_user_role_seq cache 20 increment by 1 start with 100 nomaxvalue;
hibernate中的映射文件可这么写:
  <id name="id" type="java.lang.Long" column="ID"> 
           <generator class="sequence" >
              <param name="sequence"> t_user_role_seq </param>
           </generator> 
  </id>
小结:
对于oracle数据库:
如果单纯的多对多关系不生成中间表的配置文件那中间表就不要ID主键,只要useridroleid两个外键。
如果中间表设置一个字段id作为主键,那么就需要配置中间表文件,并设置sequence,这是因为oracle的主键不会自动增加,需要通过设置sequence来增加。
 
 
附录:id生成方式
1
,序列sequence 只适用于Oracle
<id name="id" column="id"> 
<generator class="sequence"> 
<param name="sequence">person_seq</param><!--指定sequence名--> 
</generator> 
</id>
2,自增列,适用于SQLServerMySql
<id name="id" column="id"> 
      <generator class="identity"/> 
</id>
3,取最大值加一
<id name="id" column="id" type="integer"> 
      <generator class="increment"/> 
</id>
4,根据底层数据库指定生成方法
<id name="id" column="id"> 
      <generator class="native"/> 
</id>
使用缺省策略
针对Oracle数据库的生成方式还是sequence,只不过需要一个特定名字的sequence"hibernate_sequence"
5,高低位算法
<id name="id" column="id"> 
<generator class="hilo"> 
<param name="table">high_value</param> 
<!--设置高位值取值的表--> 
<param name="column">next_value</param> 
<!--设置高位值取值的字段--> 
<param name="max_lo">50</param> 
<!--指定低位最大值,当取道最大值是会再取一个高位值再运算--> 
</generator> 
</id>
以上是hilo算法的普通形式,不适合用于squenece
在一个会话中保存多个对象

4
0
分享到:
评论
1 楼 meadlai 2010-07-31  
Caused by: java.sql.BatchUpdateException: ORA-02291: 违反完整约束条件 (SYSTEM.MID_TABLE_REF_FK) - 未找到父项关键字
错误,中间表已经添加到hb.cfg里面了。

相关推荐

    Hibernate中主键生成策略

    一种优化的主键生成方式,使用较小的整数范围(高位数)和数据库表中的行(低位数)来生成主键,减少对数据库的访问。使用`&lt;generator class="hilo"&gt;`。 理解并正确选择主键生成策略对于优化数据库性能、保证数据...

    hibernate使用主键关联的一对一关系

    在这个场景中,“hibernate使用主键关联的一对一关系”指的是通过共享主键来实现两个实体类之间的这种一对一绑定。下面我们将深入探讨这一主题。 首先,我们需要理解一对一关系的概念。在数据库中,一对一关系意味...

    hibernate映射主键生成策略native

    本文将重点介绍在Oracle数据库环境下,使用Hibernate的“native”策略来生成主键的具体方法及注意事项。 #### 二、主键生成策略概述 在Hibernate中,主键生成策略主要包括以下几种: - **identity**:由数据库...

    hibernate中自动生成主键的办法

    综上所述,Hibernate提供了丰富的主键生成策略,涵盖了从简单的自动增长到复杂的分布式唯一ID生成。开发者应根据具体的应用需求和数据库特性,选择最合适的主键生成策略,以确保系统的稳定性和性能。无论是追求高...

    Hibernate映射文件主键的生成

    以上就是Hibernate主键生成的常见策略,每种策略都有其适用的场景。在实际开发中,应根据数据库类型和需求选择合适的主键生成策略,确保数据的一致性和完整性。理解并正确配置这些策略,将有助于提高程序的稳定性和...

    常用Hibernate主键生成策略

    ### 常用Hibernate主键生成策略详解 #### 一、引言 在数据库设计与操作过程中,主键是确保数据唯一性的关键要素之一。在实际应用中,开发者经常需要处理不同类型的数据库,并且需要应对各种不同的主键生成需求。...

    hibernate主键生成策略详解

    ### hibernate主键生成策略详解 #### 一、assigned **assigned** 主键生成策略意味着主键的值是由外部程序负责生成的,并且在执行 `save()` 方法之前必须明确指定一个值。在这种策略下,Hibernate 不参与主键的...

    Hibernate各种主键生成策略与配置详解

    - 当需要对主键生成具有完全控制权时使用,例如与其他系统的ID保持一致或遵循特定规则生成ID等。 - 不推荐常规使用,因为这增加了开发者的负担。 #### 三、increment - 自动递增 **定义:** `increment`策略允许...

    Hibernate的主键生成方式

    ### Hibernate的主键生成方式详解 #### 一、概述 在使用Hibernate进行对象关系映射时,一个重要的概念就是如何为持久化实体类中的主键字段生成唯一标识符。主键是表中的一列或一组列,其值是唯一的,用于唯一地...

    hibernate 主键生成策略

    - **描述**:Hibernate 自动为主键分配一个递增的值,但此策略仅在一个 JVM 实例内有效,因此在多线程或多实例环境下可能引发问题。 - **应用场景**:适用于单机应用或测试环境,但在生产环境中应谨慎使用。 #### 4...

    Hibernate的主键生成策略

    本文将详细介绍Hibernate中五种常用的主键生成策略:assigned、increment、hilo、seqhilo以及native,并探讨它们的特点、应用场景及配置方式。 #### 二、assigned **定义与用途:** - **定义:**assigned策略允许...

    Hibernate自动生成表demo

    在本教程中,我们将探讨如何利用Hibernate的注解功能,通过实体类自动生成数据库中的表。这极大地简化了数据库建模过程,同时也减少了手动编写SQL语句的工作量。 首先,我们需要理解Hibernate的核心概念。ORM框架如...

    Hibernate主键策略-sequence

    总结,"Hibernate主键策略-sequence"是利用数据库序列来生成主键的一种方式,具有性能优势但可能涉及跨应用的同步问题。了解和正确使用这一策略,能够帮助开发者更好地设计和实现数据持久化的系统。

    hibernate3 注释生成复合主键或者嵌入式主键的方法及实例.doc

    这篇文档将介绍如何使用Hibernate注解来生成复合主键或嵌入式主键。 复合主键(Composite Key)是指由两个或更多个列共同构成的唯一标识,而嵌入式主键(Embedded Key)则是将主键字段嵌入到实体类内部。在不使用...

    Hibernate主键生成策略.docx

    ### Hibernate 主键生成策略详解 #### 一、概述 Hibernate 是一种流行的 Java 持久化框架,它简化了数据库操作,并提供了多种主键生成策略。主键是表中的一个或多个字段组合,用于唯一标识表中的每一条记录。...

    hibernate-主键生成方式[自动、手动]-annotation

    本文是讲解的是hibernate3.2的主键生成方式,通过annotation来实现,详细的分析了主键在hibernate的生成以及在真实项目的运用。。。。

    Hibernate联合主键的例子

    - 在使用联合主键时,通常不需要生成自增的ID,因为主键是通过组合多个字段生成的。 - 联合主键的每个字段通常都会设置为`@Column(nullable = false)`,确保它们在数据库中都是非空的。 通过以上步骤,你就可以在...

    Hibernate 一对一关联映射(主键关联VS唯一外键关联)

    总结,主键关联和唯一外键关联都是Hibernate实现一对一映射的有效方式,各有优缺点。开发者应根据具体业务需求和数据模型,选择合适的关联策略。理解并熟练运用这些关联映射,对于提升Java后端开发的效率和代码质量...

Global site tag (gtag.js) - Google Analytics