当前位置: 首页 > 面试题库 >

JavaHibernate JPA序列(非Id)

窦凯定
2023-03-14
问题内容

是否可以对不是标识符/不是复合标识符一部分的某些列使用DB序列?

我正在使用hibernate作为jpa提供程序,并且我有一个表,其中包含一些生成的值(使用序列)的列,尽管它们不是标识符的一部分。

我想要的是使用序列为实体创建新值,其中序列的列不是主键(的一部分):

@Entity
@Table(name = "MyTable")
public class MyEntity {

    //...
    @Id //... etc
    public Long getId() {
        return id;
    }

   //note NO @Id here! but this doesn't work...
    @GeneratedValue(strategy = GenerationType.AUTO, generator = "myGen")
    @SequenceGenerator(name = "myGen", sequenceName = "MY_SEQUENCE")
    @Column(name = "SEQ_VAL", unique = false, nullable = false, insertable = true, updatable = true)
    public Long getMySequencedValue(){
      return myVal;
    }

}

然后,当我这样做时:

em.persist(new MyEntity());

该ID将被生成,但该mySequenceVal属性也将由我的JPA提供程序生成。

为了清楚起见:我希望Hibernate生成该mySequencedValue属性的值。我知道Hibernate可以处理数据库生成的值,但是我不想使用触发器或Hibernate本身以外的其他任何东西来为我的属性生成值。如果Hibernate可以为主键生成值,为什么它不能为简单属性生成?


问题答案:

寻找这个问题的答案,我偶然发现了这个链接

似乎Hibernate / JPA无法自动为你的非id属性创建一个值。该@GeneratedValue注释只有配合使用@Id,以创建自动编号。

@GeneratedValue注释只是告诉Hibernate数据库已生成该值本身。

该论坛中建议的解决方案(或解决方法)是使用生成的ID创建一个单独的实体,如下所示:

@Entity
public class GeneralSequenceNumber {
  @Id
  @GeneratedValue(...)
  private Long number;
}

@Entity 
public class MyEntity {
  @Id ..
  private Long id;

  @OneToOne(...)
  private GeneralSequnceNumber myVal;
}


 类似资料:
  • 问题内容: 是否可以对 不是标识符/不是复合标识符一部分的 某些列使用DB序列? 我正在将hibernate用作jpa提供程序,并且我有一个表,其中包含一些生成的值(使用序列)的列,尽管它们不是标识符的一部分。 我想要的是使用序列为实体创建新值,其中序列的列 不是 主键(的一部分): 然后,当我这样做时: 该ID将被生成,但该属性也将由我的JPA提供程序生成。 为了清楚起见:我希望 Hiberna

  • 问题内容: 如果我有串,我要检查,如果它作为一个连续存在 串 中,我可以使用: 在非连续子 序列 的情况下,我可以使用什么?例: 问题答案: 我不知道是否有内置功能,但是手动操作相当简单

  • 我使用了Gson,但我需要转换器只序列化非空值或非空值。 例如: 现在,将该对象转换为json的Gson实例如下所示

  • 问题内容: 我是Django REST框架的初学者,需要你的建议。我正在开发Web服务。该服务必须提供与其他服务的REST接口。我需要实现的REST接口无法直接与我的模型一起使用(我的意思是获取,放置,发布,删除操作)。相反,它为其他服务提供了一些计算结果。根据请求,我的服务会进行一些计算,只是将结果返回(不将结果存储在自己的数据库中)。 以下是我对如何实现REST接口的理解。纠正我,如果我错了。

  • 我是Django REST框架的初学者,需要您的建议。我正在开发一个web服务。该服务必须向其他服务提供REST接口。我需要实现的REST接口并不直接与我的模型一起工作(我指的是get、put、post和delete操作)。取而代之的是,它向其他服务提供一些计算结果。在一个请求中,我的服务进行一些计算并返回结果(不将结果存储在自己的数据库中)。 下面是我对如何实现REST接口的理解。纠正我,如果我

  • 问题内容: public class SequenceControlNumber extends SequenceGenerator { 在我的模型类中,这是我的注释: 但我不断收到一个属性值异常。 问题答案: 检查类中generate方法返回的值。 BTW在以下SO问题中检查此响应:hibernateJPA序列(非ID)