Hibernate主键生成方式 Key Generator
主键产生器
可选项说明:
1) assigned
主键由外部程序负责生成,无需Hibernate参与。
2) hilo
通过hi/lo 算法实现的主键生成机制,需要额外的数据库表保存主键生成历史状态。
3) seqhilo
与hilo 类似,通过hi/lo 算法实现的主键生成机制,只是主键历史状态保存在Sequence中,适用于支持Sequence的数据库,如Oracle。
4) increment
主键按数值顺序递增。此方式的实现机制为在当前应用实例中维持一个变量,以保存着当前的最大值,之后每次需要生成主键的时候
将此值加1作为主键。
这种方式可能产生的问题是:如果当前有多个实例访问同一个数据库,那么由于各个实例各自维护主键状态,不同实例可能生成同样的主键,从而造成主键重复异常。因此,如果同一数据库有多个实例访问,此方式必须避免使用。
5) identity
采用数据库提供的主键生成机制。如DB2、SQL Server、MySQL中的主键生成机制。
6) sequence
采用数据库提供的sequence 机制生成主键。如Oralce 中的Sequence。
7) native
由Hibernate根据底层数据库自行判断采用identity、hilo、sequence其中一种作为主键生成方式。
8) uuid.hex
由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后以长度32 的字符串表示)作为主键。
9) uuid.string
与uuid.hex 类似,只是生成的主键未进行编码(长度16)。在某些数据库中可能出现问题(如PostgreSQL)。
10) foreign
使用外部表的字段作为主键。
<clk> 一般而言,利用uuid.hex方式生成主键将提供最好的<nobr oncontextmenu="return false" id="clickeyekey0" onmousemove="kwM(0)" onmouseover="kwE(event,0, this)" onclick="kwC(event,0)" onmouseout="kwL(event,this)" style="COLOR: #6600ff; BORDER-BOTTOM: #6600ff 1px dotted; BACKGROUND-COLOR: transparent; TEXT-DECORATION: underline">性能</nobr>和数据库平台适应性。</clk>
另外由于常用的数据库,如Oracle、DB2、SQLServer、MySql 等,都提供了易用的主键生成机制(Auto-Increase 字段或者Sequence)。我们可以在数据库提供的主键生成机制上,采用generator-class=native的主键生成方式。不过值得注意的是,一些数据库提供的主键生成机制在效率上未必最佳,大量并发insert数据时可能会引起表之间的互锁。
数据库提供的主键生成机制,往往是通过在一个内部表中保存当前主键状态(如对于自增型主键而言,此内部表中就维护着当前的最大值和递增量),之后每次插入数据会读取这个最大值,然后加上递增量作为新记录的主键,之后再把这个新的最大值更新回内部表中,这样,一次Insert操作可能导致数据库内部多次表读写操作,同时伴随的还有数据的加锁解锁操作,这对性能产生了较大影响。
因此,对于并发Insert要求较高的系统,推荐采用uuid.hex 作为主键生成机制。
相关推荐
### hibernate主键生成策略详解 #### 一、assigned **assigned** 主键生成策略意味着主键的值是由外部程序负责生成的,并且在执行 `save()` 方法之前必须明确指定一个值。在这种策略下,Hibernate 不参与主键的...
### Hibernate主键生成策略 #### 一、概述 在Hibernate框架中,主键生成策略是对象持久化过程中不可或缺的一部分。合理的主键生成机制不仅能够确保数据的唯一性,还能够提高系统的性能和可扩展性。本文将详细介绍...
- **实现机制**:该策略由`org.hibernate.id.IdentifierGenerator`接口实现,通过递增的方式生成主键值。 - **应用场景**:当数据表中的记录数量相对较少,并且不会同时有多个进程尝试插入数据时,可以使用此策略。 ...
以上就是Hibernate主键生成的常见策略,每种策略都有其适用的场景。在实际开发中,应根据数据库类型和需求选择合适的主键生成策略,确保数据的一致性和完整性。理解并正确配置这些策略,将有助于提高程序的稳定性和...
以下是对Hibernate主键类型及其配置的详细说明: 1. **uuid.hex**: 这种生成器使用128位算法生成一个32位的字符串。由于其通用性,它适用于所有类型的数据库。在`.hbm.xml`映射文件中,你可以这样配置: ```xml ...
在Java的持久化框架Hibernate中,复合主键(Composite Key)是一种特殊的数据模型,它用于表示由多个属性共同构成的唯一标识。这种设计通常出现在实体类的某些属性组合起来才能唯一确定一个对象的情况下。本篇文章将...
4. 主键生成器(Key Generator):用于决定如何生成对象的唯一标识(主键)。`Assigned`表示主键由程序员手动管理,`hilo`和`seqhilo`使用hi/lo算法,适用于需要高效主键生成的场景,但可能需要额外的数据库表或序列...
在使用这个策略时,JPA会将主键的生成工作交由数据库完成,hibernate 不会介入。这意味着,数据库将负责生成主键,而不是hibernate。这种策略适用于大多数情况,因为它可以确保主键的唯一性和连续性。 uuid uuid是...
通过对以上几种Hibernate主键生成策略的介绍与分析,我们可以看出每种策略都有其独特的适用场景和优缺点。在实际开发过程中,应根据具体需求和技术栈来合理选择主键生成策略,以达到最佳的数据处理效果。此外,随着...
- **功能**:声明一个Hibernate主键生成策略,支持多种策略。 - **属性**: - `name`:生成器名称。 - `strategy`:具体生成策略。 - `parameters`:获取具体的生成器所用到的参数。 - **示例**: ```java @...
这种策略在Annotation情况下,主要有三种方式生成主键值。 第一种方式是使用数据库的自动增长字段生成。这种方式使用@GeneratedValue(strategy=GenerationType.IDENTITY)注解,适用于SQL Server和Mysql等数据库管理...
7. `key-generator`:主键生成器,用于定义如何生成数据库主键。常见的选项有: - `assigned`:主键由应用程序自己生成。 - `hilo`、`seqhilo`:基于hi/lo算法,适用于需要高效主键生成的场景。 - `increment`:...
- `generator`:指定生成主键的生成器。 - **示例**: ```java @Entity @Table(name = "users") public class User { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; // 其他...
4. 主键生成策略在 XML 中通过 `<generator>` 元素定义,常见的策略包括 `native`(根据数据库自动选择)、`increment`(自增)、`assigned`(手动分配)。级联操作的属性值可能有 `save-update`, `delete`, `all` ...
- `<generator>` 标签中的 `class` 属性设置了主键生成策略,`assigned` 表示主键值由外部提供,即用户手动设置。 - `<property>` 标签用于定义非主键属性,其格式与 `<id>` 类似。 #### 二、单主键、有外键的...
通过这种方式,Hibernate会自动处理一对一关联的主键同步,确保数据的一致性。双向关联使得在任何一方都可以方便地获取到关联的另一方,提高了代码的可读性和易用性。 总结来说,Hibernate中的一对一主键关联映射是...
`id`元素定义了实体的主键,`generator`子元素则定义了主键的生成策略。在示例中,`increment`策略表示主键值会在每次插入新记录时自动递增。 4. 关联映射 Hibernate支持一对一、一对多、多对一、多对多四种关联...