Hibernate主键生成策略详解:assigned、increment、hilo等

需积分: 10 2 下载量 67 浏览量 更新于2024-09-16 收藏 118KB PDF 举报
Hibernate 主键生成策略与配置详解 Hibernate 是一个流行的 Java 持久层框架,提供了多种主键生成策略来满足不同的需求。在本文中,我们将详细介绍 Hibernate 中的各种主键生成策略与配置。 1. assigned 策略 assigned 策略是 Hibernate 中最简单的主键生成策略。在这个策略中,主键由外部程序负责生成,在 save() 之前必须指定一个。Hibernate 不负责维护主键生成,与 Hibernate 和底层数据库都无关,可以跨数据库。在存储对象前,必须使用主键的 setter 方法给主键赋值,至于这个值怎么生成,完全由自己决定。 配置示例: ``` <id name="id" column="id"> <generator class="assigned"/> </id> ``` 特点:可以跨数据库,人为控制主键生成,应尽量避免。 2. increment 策略 increment 策略是 Hibernate 中的一种主键生成策略,由 Hibernate 从数据库中取出主键的最大值,以该值为基础,每次增量为 1,在内存中生成主键,不依赖于底层的数据库,因此可以跨数据库。 配置示例: ``` <id name="id" column="id"> <generator class="increment"/> </id> ``` Hibernate 调用 org.hibernate.id.IncrementGenerator 类里的 generate() 方法,使用 select max(idColumnName) from tableName 语句获取主键最大值。该方法被声明成了 synchronized,所以在一个独立的 Java 虚拟机内部是没有问题的,然而,在多个 JVM 同时并发访问数据库 select max 时就可能取出相同的值,再 insert 就会发生 DuplicateEntry 的错误。所以只能有一个 Hibernate 应用进程访问数据库,否则就可能产生主键冲突,所以不适合多进程并发更新数据库,适合单一进程访问数据库,不能用于群集环境。 官方文档:只有在没有其他进程往同一张表中插入数据时才能使用,在集群下不要使用。 特点:跨数据库,不适合多进程并发更新数据库,适合单一进程访问数据库,不能用于群集环境。 3. hilo 策略 hilo(高低位方式 high-low)是 Hibernate 中最常用的一种生成方式,需要一张额外的表保存 hi 的值。保存 hi 值的表至少有一条记录(只与第一条记录有关),否则会出现错误。可以跨数据库。 配置示例: ``` <id name="id" column="id"> <generator class="hilo"> <param name="table">hibernate_unique_key</param> </generator> </id> ``` 特点:跨数据库,需要额外的表保存 hi 值,适合大多数情况。 Hibernate 提供了多种主键生成策略,每种策略都有其特点和适用场景。开发者可以根据实际情况选择合适的策略,以确保数据的一致性和安全性。