一尘不染

Spring Data JPA JpaRepository.save(entity)不返回数据库默认值

hibernate

我有一个很简单的问题。在单个事务中,我的代码如下所示:

MyClass c = new MyClass();
c.setPropA("A");

c = myClassRepository.save(c);

c.setPropC("C");

我的实体看起来像这样:

@Entity
@Table(name = "MY_CLASS")
public class MyClass {
  private String propA;
  private String propB;
  private String propC;

  @Id
  @Column(name = "PROP_A", unique = true, nullable = false, updatable = false)
  public String getPropA() { return propA; }
  public void   setPropA(String propA) { this.propA = propA; }

  @Column(name = "PROP_B", insertable = false)
  public String getPropB() { return propB; }
  public void   setPropB(String propB) { this.propB = propB; }

  @Column(name = "PROP_C")
  public String getPropC() { return propC; }
  public void   setPropC(String propC) { this.propC = propC; }
}

像这样建立数据库(Dialect = Oracle 11G)

CREATE TABLE MY_CLASS {
  PROP_A VARCHAR2 NOT NULL PRIMARY KEY,
  PROP_B VARCHAR2 DEFAULT 'B' NOT NULL,
  PROP_C VARCHAR2
}

因此,基于持久化实体的代码,我认为我会得到如下所示的查询:

MyClass c = new MyClass();
c.setPropA("A");

c = myClassRepository.saveAndFlush(c);
// INSERT INTO MY_CLASS (PROP_A, PROP_C) VALUES ("A", NULL)
// SELECT PROP_A, PROP_B, PROP_C FROM MY_CLASS -- to refresh `c`

c.setPropC("C");

// After transaction ends, flush change to `c.propC`
// UPDATE MY_CLASS SET PROP_B = "B", PROP_C = "C" WHERE PROP_A = "A"

…但是SELECT永远不会发生。为什么实体没有刷新?

由于UPDATE(立即)跟随INSERTc.propB仍然而中断了该操作null。我得到一个ORA-01407: cannot update ("MY_SCHEMA"."MY_CLASS"."PROP_B") to NULL堆栈跟踪。

我意识到有很多方法可以在Java中使用@PrePersist或设置默认值columnDefinition,但是我不必重复默认值。

注意:这在我org.hibernate.Session.saveOrUpdate()代替Spring Data JPA进行此操作之前有效。

在此先感谢您的帮助!


阅读 955

收藏
2020-06-20

共1个答案

一尘不染

Hibernate不知道B是由数据库生成的,并且它必须在插入后读取它,除非您使用@Generated批注指示它这样做。

2020-06-20