单个实体 Spring Data JPA 中的“自动生成的 PK 作为 Id”和“自动生成的 UUID 作为字符串”

Posted

技术标签:

【中文标题】单个实体 Spring Data JPA 中的“自动生成的 PK 作为 Id”和“自动生成的 UUID 作为字符串”【英文标题】:"Autogenerated PK as Id" and "Autogenerated UUIDs as String" in a single Entity Spring Data JPA 【发布时间】:2020-06-25 19:46:47 【问题描述】:

我的问题是对this、this 和我自己的previous question 的扩展。

经过大量其他阅读后,我的实体中有以下内容:

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private Long id;

@Column(name = "useruuid")
@GenericGenerator(name = "uuid", strategy = "uuid4")
private String useruuid;

问题 1: 上述声明是否有效? @Id 肯定是的,因为我们都知道。问题更集中在@GenericGenerator(name = "uuid", strategy = "uuid4"). 上,这意味着在已经拥有@GeneratedValue 的实体中生成UUID。可以接受吗?我试过了,效果很好。

问题 2: 如果上面是肯定的,那么生成的 UUID 作为字符串对于整个数据库是唯一的还是仅对实体是唯一的?我在这里寻求帮助,因为我将在同一数据库中的其余实体中使用相同的模式。

【问题讨论】:

【参考方案1】:

是的@GenericGenerator(name = "uuid", strategy = "uuid4") 是可以接受的并且完全正确。

现在谈到您的第二个问题,生成的 UUID 在整个数据库中是唯一的。事实上,它是全球唯一的,因此 UUID 被称为“全球唯一标识符”(GUID)。

除非多年内每秒生成十亿个 UUID,否则您不会看到两个 UUID 第 4 版实现发生冲突。

阅读:How unique is UUID?

【讨论】:

不错。我想知道为什么我找不到您共享的 SO 链接。那里有很好的信息。感谢分享。

以上是关于单个实体 Spring Data JPA 中的“自动生成的 PK 作为 Id”和“自动生成的 UUID 作为字符串”的主要内容,如果未能解决你的问题,请参考以下文章

Spring Data 系列学习Spring Data JPA 自定义查询,分页,排序,条件查询

Spring Data JPA - JpaRepository 中的自定义排序

使用 spring data jpa 更新单个字段

Spring Data JPA 查询结果返回至自定义实体

使用 spring-data-jpa 自定义 ItemReader

Spring Data JPA:嵌套实体的批量插入