Spring Data JPA JpaRepository.save(实体)不返回数据库默认值
我有一个相当简单的问题。 在单个事务中,我的代码看起来像这样:
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
紧跟INSERT
并且c.propB
仍为null
,因此会c.propB
。 我得到一个ORA-01407: cannot update ("MY_SCHEMA"."MY_CLASS"."PROP_B") to NULL
堆栈跟踪。
我知道有很多方法可以使用@PrePersist
或在Java中的columnDefinition
上设置默认值,但我不应该重复默认值。
注意:这在我使用org.hibernate.Session.saveOrUpdate()
而不是Spring Data JPA进行此操作之前有效。
在此先感谢您的帮助!
Hibernate不知道B是由数据库生成的,并且它必须在插入后读取它,除非您使用@Generated
注释告诉它这样做。