我使用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)。
不幸的是我没有找到关于如何以及为什么的任何文档。有人能指出我正确的方向吗?
由于
答案 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返回到数据库以获取密钥。