gpt4 book ai didi

java - 通过 Hibernate 检索 Oracle 序列

转载 作者:行者123 更新时间:2023-12-02 00:14:52 25 4
gpt4 key购买 nike

我在oracle中定义了以下序列:

CREATE SEQUENCE MySequence
MINVALUE 65536
MAXVALUE 4294967296
START WITH 65536
INCREMENT BY 1
CYCLE
NOCACHE
ORDER;

我想知道如何通过 Hibernate 访问它(每次请求的下一个值)? (通过 JDBC,我使用了 getGENerateKeys)

在另一个需要持久化的实体上使用该 ID 之前,我需要该 ID。

谢谢

最佳答案

对于 Oracle,您应该使用GenerationType.SEQUENCE

  @Id
@GeneratedValue(generator="MySequence", strategy=GenerationType.SEQUENCE)
@SequenceGenerator(allocationSize=1, name="MySequence", sequenceName="MySequence")

编辑:序列名称已更新

编辑:引用您的评论: 您的要求听起来像是使用序列的复合/嵌入 id(使用多列作为主键)。但不幸的是,这两种解决方案都不支持序列生成器。到目前为止我可以说;

*您可以通过 hibernate 创建 native 查询并使用“select mySequence.nextval from Dual”附加到索引号。

*或者您可以使用新列为其创建一个 Oracle View ,该新列通过子查询显示序列 + 索引。

*这个非常实验性,我没有尝试,但你可以使用 @formula 注释。示例here .

关于java - 通过 Hibernate 检索 Oracle 序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12050843/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com