为什么OpenJPA集群自动生成ID?

时间:2014-04-01 12:02:08

标签: java jpa openjpa

我使用OpenJPA 2.1.0作为带注释的持久性逻辑。我的实体中的主键注释如下:

@Id
@GeneratedValue
@Column(name = CONVERSATION_ID)
private long id;

我意识到生成的id以某种方式聚类为1,2,3,11,12,13,21,22,23等。

我从OpenJPA文档中了解到,默认情况下应用了GeneratorStrategy.AUTO,具体的生成策略取决于JPA供应商(http://openjpa.apache.org/builds/2.1.0/apache-openjpa-2.1.0/docs/manual/main.html)。

不幸的是我没有找到关于如何以及为什么的任何文档。有人能指出我正确的方向吗?

由于

1 个答案:

答案 0 :(得分:1)

当您在没有策略的情况下使用@GeneratedValue注释时,OpenJPA默认为AUTO,而大多数数据库OpenJPA支持使用表生成。默认的allocationSize是50,所以我希望看到你的密钥类似于1,2,3,4,5,51,52,53,54,101等。这是因为每次你重新启动你的EntityManagerFactory(或应用程序) OpenJPA必须返回数据库才能获得另一批密钥。

我不确定为什么你会看到10的分配,但我很确定这会解释你所看到的。如果您要启用sql跟踪(openjpa.Log=SQL=trace),您会看到OpenJPA返回到数据库以获取密钥。