我使用OpenJPA 2.1.0作为持久化逻辑和注释。对my实体中的主键进行注释,如下所示:
@Id
@GeneratedValue
@Column(name = CONVERSATION_ID)
private long id;我意识到生成的ids以某种方式聚集在一起,比如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)。
不幸的是,我没有找到任何关于如何和为什么的文档。谁能给我指明正确的方向吗?
谢谢
发布于 2014-04-02 19:21:14
当您使用没有策略的@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返回到DB获取密钥。
https://stackoverflow.com/questions/22785287
复制相似问题