Hibernate映射文件(*.hbm.xml)中的<id>元素定义持久化类的标识符属性名、类型和与数据库表中字段的映射,其<generator>子元素则用来设置当前持久化类的标识符属性的生成策略。
一个持久化对象对应数据库表中的一条记录,为了更好地持久化表中的每一条记录,需要通过<generator>元素的class属性设置采用的标识符属性生成策略,如下面的代码所示:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="increment">
</generator>
</id>
<param>元素是<generator>元素的可选子元素,用来传递标识符属性生成时可能需要的一个或多个参数。
在Hibernate中内置了多种标识符属性生成策略,如果不能满足需要,还可以通过实现org.hibernate.id.IdentifierGenerator接口来定制标识符属性生成策略。
1.increment生成策略
当Hibernate准备在数据库表中插入一条新记录时,首先从数据库表中获取当前主键字段的最大值,然后在最大值基础上加1,作为当前持久化对象的标识符属性值。这种策略即increment生成策略,用其生成的标识符属性的类型可以是long、short、int及其封装类的类型。
这种主键生成策略适合单服务器的Hibernate应用,同时数据库也只被这个Hibernate应用所独享;否则不能保证生成的标识符属性值的唯一性,即这种标识符属性生成策略并不适合非独享数据库或者分布式的Hibernate应用。
使用这种标识符属性生成策略的示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="increment">
</generator>
</id>
2.identity生成策略
在MS SQL Server、MySQL和DB2等数据库中可以设置表中某一个字段的数值自动增长,identity生成策略通过这种方式为当前记录获取主键值的同时为持久化对象赋予标识符属性值。
该生成策略生成的标识符属性的类型可以是long、short、int及其封装类的类型。
使用这种标识符属性生成策略的示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="identity">
</generator>
</id>
3.sequence生成策略
在Oracle、DB2和PostgreSQL等数据库中创建一个序列(sequence),然后Hibernate通过该序列为当前记录获取主键值,进而为持久化对象赋予标识符属性值。此即sequence生成策略,用其生成的标识符属性的类型可以是long、short、int及其封装类的类型。
使用这种标识符属性生成策略的示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="sequence">
<param name="sequence">gb_seq</param>
</generator>
</id>
第3行指定Hibernate使用的序列名,该行为可选。如果未指定序列名,则Hibernate默认使用名为"hibernate_sequence"的序列。
4.hilo生成策
hilo生成策略采用一种称为"高/低位"(hi/lo)的高效算法产生标识符属性值,所产生的标识符属性值为long、short、int及其封装类的类型。该算法使用一个高位值(hi)和一个低位值(lo),然后计算其值,运算结果作为标识符属性值。
使用这种标识符属性生成策略需要在数据库中建立一个表和一个字段(默认表名为"hibernate_unique_key",字段名为"next_hi",该字段要有数值)作为高位值的来源。使用这种标识符属性生成策略的示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="hilo">
<param name="table">hibernate_key</param>
<param name="column">next_hivalue</param>
</generator>
</id>
这种标识符属性生成策略需要额外的数据库表和字段的支持,可保证为特定数据库生成唯一的标识符属性。并且这种策略与底层使用的数据库无关,可以跨数据库使用。
5.seqhilo生成策略
seqhilo生成策略也使用高/低位算法,产生的标识符属性值为long、short、int及其封装类的类型。与hilo生成策略不同的是,它使用指定的sequence获取高位值。使用这种标识符属性生成策略的示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="seqhilo">
<param name="sequence">hibernate_seq</param>
</generator>
</id>
第3行指定Hibernate使用的序列名,该行为可选。如果未指定序列名,则Hibernate默认使用名为"hibernate_unique_sequence"的序列。
6 uuid生成策略
uuid生成策略采用128位的UUID算法来生成一个字符串类型的主键值,这个算法使用IP地址、JVM的启动时间(精确到1/4秒)、系统时间和一个计数器值(在当前的JVM中唯一)经过计算来产生标识符属性值,可以用于分布式的Hibernate应用中。产生的标识符属性是一个32位长度的字符串。使用这种生成策略,对应持久化类中标识符属性的类型应该设置为String类型,其示例配置信息如下所示。
<id name="id" type="java.lang.String" column="ID">
<generator class="uuid">
</generator>
</id>
这种标识符属性生成策略生成的数值可以保证多个数据库之间的唯一性,由于该值是32位长的字符串,所以占用的数据库空间较大。推荐在实际开发中使用这种生成策略。
7 guid生成策略
这种标识符属性生成策略借助MS SQL Server或者MySQL数据库中的GUID字符串产生标识符属性值。如果使用MS SQL Server数据库,表中需要把标识符属性对应的字段类型设置为"uniqueidentifier"。其示例配置信息如下:
<id name="id" type="java.lang.String" column="ID">
<generator class="guid">
</generator>
</id>
8 native生成策略
由Hibernate根据所使用的数据库支持能力从identity、sequence或者hilo生成策略中选择一种,其示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="native">
</generator>
</id>
使用这种标识符属性生成策略可以根据不同的数据库采用不同的生成策略,如Oracle中使用sequence,在MySQL中使用identity便于Hibernate应用在不同的数据库之间移植。
9 assigned生成策略
assigned生成策略由Hibernate应用自定义标识符属性的数值,即在调用Session对象的save()方法持久化对象时,需要首先为持久化对象的标识符属性赋值。
如果<generator>元素没有设置主键生成策略,则默认为assigned生成策略,其示例配置信息如下:
<id name="id" type="java.lang.Integer" column="ID">
<generator class="assigned"></generator>
</id>
10 foreign生成策略
foreign生成策略通过关联的持久化对象为当前持久化对象设置标识符属性值,当处理持久化类一对一关联时,一个持久化类的标识符属性值可以参考关联持久化类的标识符属性值获取。
例如,User类和Profile类标识符属性都是id,二者是一对一的关联关系。可以设置Profile类的标识符属性值通过User类的标识符属性获取,Profile.hbm.xml文件中关于标识符属性的设置信息如下:
<id name="id" type="java.lang.Integer" column="ID" >
<generator class="foreign">
<param name="property">user</param>
</generator>
</id>
11 选择标识符属性生成策略
在选择Hibernate提供的标识符属性生成策略时,要具体问题具体分析,如果应用系统不需要分布式部署,在数据库支持的情况下使用sequence、identity、hilo、seqhilo和uuid生成策略都是不错选择;如果应用需要使用多个数据库或者进行分布式的部署,则uuid生成策略是最佳的选择。还有一种情况是使用Hibernate改造遗留系统,可能需要人工采用一定的规则为标识符属性赋值,这时使用assigned生成策略比较合适。
分享到:
相关推荐
### ID生成策略详解 在软件开发中,尤其是数据库应用领域,如何高效且合理地生成唯一标识符(ID)是至关重要的。本文将详细介绍几种常见的ID生成策略:`sequence`、`native`、`identity`、`foreign`等,并探讨它们...
这个例子可能包括了如何生成 Entity 类、DAO 接口及其实现,以及 Mapper XML 文件,并且可能展示了如何处理复杂的表关联、主键生成策略等。 总之,自定义 MyBatis 代码生成策略是一项实用的技术,它可以帮助我们...
主键生成策略是Hibernate中一个重要的概念,因为它决定了如何为实体生成唯一的标识符。本文将详细解释Hibernate的几种主键生成策略及其配置。 1. assigned策略 assigned策略允许开发者在保存对象之前手动设置主键。...
### 常用Hibernate主键生成策略详解 #### 一、引言 在数据库设计与操作过程中,主键是确保数据唯一性的关键要素之一。在实际应用中,开发者经常需要处理不同类型的数据库,并且需要应对各种不同的主键生成需求。...
在数据交换研究中,可以模拟不同格式的XML数据,探讨最佳的数据转换策略;在数据存储的研究中,可以生成复杂结构的XML文件,研究XML数据库的性能和效率。 使用XML数据生成器V1.0版,科研人员无需手动编写XML文档,...
分布式ID生成策略是现代互联网应用中的重要组成部分,尤其是在大数据时代,每个请求、每条记录往往都需要一个全局唯一的标识。Snowflake算法就是一种被广泛使用的分布式ID生成方案,它由Twitter开源,具有时间戳、...
在某些情况下,开发者可能会遇到MyBatis-Plus主键生成的坑,例如,预设的主键生成策略可能并不符合项目需求,这时就需要对`TableId`和`TableField`进行定制,以支持标注方法来实现主键生成。 Spring Boot与MyBatis...
这里的`@Id`注解标记`id`字段为实体的主键,而`@GeneratedValue`注解表示主键生成策略。`GenerationType.IDENTITY`意味着主键值由数据库自动生成,比如在MySQL中,这通常对应于`AUTO_INCREMENT`。 **JPA主键生成...
- 对于超大规模的系统,可以考虑使用多层ID生成策略,比如区域节点+工作节点+序列号。 通过以上步骤,我们可以在SpringBoot项目中成功地集成Vesta ID Generator,为分布式系统提供稳定、高效的全局唯一ID生成方案...
9. `<columnOverride>`:用于覆盖特定列的默认生成策略,如修改列名、是否生成getter和setter等。 在实际应用中,开发者通常会创建一个generatorConfig.xml模板,然后根据项目需求进行适当的修改。通过运行MyBatis ...
### Hibernate映射主键生成策略native #### 一、引言 在ORM(对象关系映射)技术中,Hibernate作为一款流行的Java持久层框架,在处理数据持久化方面提供了丰富的功能和灵活性。其中,主键生成策略是Hibernate配置...
本篇文章将深入探讨Android中的XML生成与解析,帮助开发者更好地理解和运用这一技术。 一、XML简介 XML是一种标记语言,它的设计目标是传输和存储数据,而不是显示数据。XML文档结构清晰,易于机器和人类阅读,支持...
### Hibernate的主键生成策略详解 #### 一、概述 在使用Hibernate进行持久化操作时,主键生成策略的选择对于数据库性能及应用架构至关重要。本文将详细介绍Hibernate中五种常用的主键生成策略:assigned、...
### hibernate主键生成策略详解 #### 一、assigned **assigned** 主键生成策略意味着主键的值是由外部程序负责生成的,并且在执行 `save()` 方法之前必须明确指定一个值。在这种策略下,Hibernate 不参与主键的...
### Hibernate 主键生成策略详解 #### 一、概述 Hibernate 是一种流行的 Java 持久化框架,它简化了数据库操作,并提供了多种主键生成策略。主键是表中的一个或多个字段组合,用于唯一标识表中的每一条记录。...
而实体类对应的XML映射文件(如`User.hbm.xml`)则定义了Java类与数据库表之间的映射关系,包括字段类型、主键生成策略等。 生成这些配置文件和映射文件的辅助类通常是为了提高开发效率,避免手动编写这些繁琐的XML...
接下来,MBG提供了多种生成策略,你可以根据需要调整。例如,你可以控制是否生成Example类,是否使用驼峰命名规则等: ```xml <generatedKey column="id" sqlType="INT" identity="true" /> <!-- ... ...