如何使用JPA的UUID主键生成策略

这篇文章只写给主键用uuid并且用jpa的小伙伴。

1. 数据实体类

@Entity
@Table(name = "ip_user")
@GenericGenerator(name = "jpa-uuid", strategy = "uuid")
public class User  implements Serializable {
    @Id
    @GeneratedValue(generator = "jpa-uuid")
    @Column(length = 32)
    private String userId;
    ...
}

注意@GenericGenerator(name = "jpa-uuid", strategy = "uuid")@GeneratedValue(generator = "jpa-uuid") 两个注解是生成策略核心注解。

2. 数据库字段

3. 执行save方法后

不需要给user.id字段设置值,jpa会自动生成uuid并作为它的主键添加到表中。

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
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; ``` 以上是一些常用的主键生成策略,你可以根据实际需求选择适合的策略。同时,也可以通过实现自定义的主键生成器来实现更加复杂的主键生成策略

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值