7

我有一个映射为实体的类以将其保存在数据库中。我有一个 id 字段作为主键,因此每次持久化对象时,都会从序列“myClass_pk_seq”中检索 id 的值,代码如下所示。

@Entity
@Table(name="myObjects")
public class MyClass {
    @Id
    @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="sequence")
    @SequenceGenerator(name="sequence", sequenceName="myClass_pk_seq", allocationSize=1)
    @Column(name="myClassId")
    private Integer id;

    private Integer code;


    ...
}

我需要在“代码”属性中添加类似于 id 的内容。我需要一个序列,以便我可以分配给序列的下一个值进行编码(以保留该值,以防用户想要保留它但不保留数据)。我的意思是用户会看到该字段,如果他不知道要输入什么,他可以按下按钮并在屏幕中接收下一个可能的值(他可以接受也可以不接受)。如何在不保留非主键字段的数据的情况下获取 JPA 中定义的序列的下一个值(并增加其值)?

我只想有一个方法,它在与“代码”字段关联的序列上调用 nextval,并返回值。在 JPA 中使用注释的最佳方法是什么?

谢谢。

4

2 回答 2

4

我只想有一个方法,它在与“代码”字段关联的序列上调用 nextval,并返回值。在 JPA 中使用注释的最佳方法是什么?

  • 当用户按下按钮时,使用本机 SQL 获取下一个序列值。手动创建序列或使用“假实体”让 JPA 为您创建它。
  • 如果您不想使用原生 SQL,请插入依赖于序列的实体并获取其 id。

这两种解决方案听起来都有些难看。也许您可以简单地使用像 UUID 生成器这样的随机生成器。

实际上,您没有提到任何关于 的唯一性code(并且 JPA 注释没有显示它必须是唯一的)。你为什么不返回一个随机整数?

于 2010-06-18T10:50:33.283 回答
-1

请参阅关于使用在 id fields 以外的其他地方定义的序列的主题的另一个问题/答案。您可以使用一个字段(Long id 类型)创建一个假实体。将其连接到您在数据库中定义的序列。然后为该实体创建一个 CrudRepository 实现,并使用您定义的假实体对象的空实例调用其 save() 方法。Hibernate 将为您运行“从双重中选择 YOUR_SEQ.NEXTVAL”查询。

于 2017-08-10T15:24:55.590 回答