JPA 主键ID生成策略

在定义Entity的ID字段时,我们可以使用@GeneratedValue注解指定以何种方式生成数据库的主键ID的值。有几种策略:

1. 默认情况下,是自动生成策略。

比如下边两种方式效果是一样的。如果使用的是Springboot JPA Data, 那hibernate会自动帮我们创建一个Sequence,然后通过该Sequence,为所有生成策略是Auto的表使用该Sequence,也就是多个表共享一个Sequence。

@Entity
public class Student {

    @Id
    @GeneratedValue
    private long studentId;

    // ...
}

@Entity
public class Student {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long studentId;

    // ...
}

2. IDENTITY生成策略。

就是ORM框架不负责生成ID,而是由数据库创建表时,将主键列,制定成自增(auto increment)。应用程序向数据库插入数据时,无需指定该列的值。

@Entity
public class Student {

    @Id
    @GeneratedValue (strategy = GenerationType.IDENTITY)
    private long studentId;

    // ...
}

3. 我们自定义的数据库的Sequence方式。 

这也是Hibernate官方推荐的方式,为每一个表创建一个Sequence。Hibernate在生成@ID标注的字段的值时,先访问数据库,查询下一个Sequence的值,再封装完整的insert语句插入数据。

@Entity
public class User {
    @Id
    @GeneratedValue(generator = "sequence-generator")
    @GenericGenerator(
      name = "sequence-generator",
      strategy = "org.hibernate.id.enhanced.SequenceStyleGenerator",
      parameters = {
        @Parameter(name = "sequence_name", value = "user_sequence"),
        @Parameter(name = "initial_value", value = "4"),
        @Parameter(name = "increment_size", value = "1")
        }
    )
    private long userId;
    
    // ...
}

另外,还有表的方式生成ID主键值,不推荐,这里不详细说了。

参考文档: 

​​​​​​​​​​​​​​https://www.baeldung.com/hibernate-identifiers

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JPA(Java Persistence API)允许开发者自定义主键生成策略。在JPA中,可以使用@GeneratedValue注解来指定主键生成策略。常用的主键生成策略有以下几种: 1. 自增长(GenerationType.IDENTITY):使用数据库自增长字段生成主键,适用于支持自增长的数据库,如MySQL、SQL Server等。 ```java @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; ``` 2. 序列(GenerationType.SEQUENCE):使用数据库序列生成主键,适用于支持序列的数据库,如Oracle。 ```java @Id @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "sequence_name") @SequenceGenerator(name = "sequence_name", sequenceName = "your_sequence_name", allocationSize = 1) private Long id; ``` 3. 表生成(GenerationType.TABLE):使用特定的数据库表来生成主键,适用于各种数据库。 ```java @Id @GeneratedValue(strategy = GenerationType.TABLE, generator = "table_name") @TableGenerator(name = "table_name", table = "your_table_name", pkColumnName = "pk_column_name", valueColumnName = "value_column_name", allocationSize = 1) private Long id; ``` 4. UUID(GenerationType.UUID):使用UUID生成主键,适用于分布式系统或无法依赖数据库自增长功能的场景。 ```java @Id @GeneratedValue(strategy = GenerationType.UUID) private String id; ``` 以上是一些常用的主键生成策略,你可以根据实际需求选择适合的策略。同时,也可以通过实现自定义的主键生成器来实现更加复杂的主键生成策略

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值