5
我有一个相当简单的问题。在一个单一的交易,我的代码看起来是这样的:Spring数据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; }
}
和数据库建立这样的(方言=甲骨文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
,因此中断。我得到一个ORA-01407: cannot update ("MY_SCHEMA"."MY_CLASS"."PROP_B") to NULL
堆栈跟踪。
我知道有些方法可以使用@PrePersist
或在Java中设置默认值columnDefinition
,但我不应该重复默认值。
注意:在我使用org.hibernate.Session.saveOrUpdate()
代替Spring Data JPA进行此操作之前,此工作方式有效。
在此先感谢您的帮助!
好抓! '@ GeneratedValue'是JPA的等价物吗? – Andy 2014-10-30 13:46:36
在我的情况下,我有一列'modified_at',默认值是当前日期时间。唯一对我有用的是[@UpdateTimestamp](https://docs.jboss.org/hibernate/orm/4.3/javadocs/org/hibernate/annotations/UpdateTimestamp.html)。我不需要调用'.flush()'。 既不[@Generated](http://docs.jboss.org/hibernate/orm/4.3/javadocs/org/hibernate/annotations/Generated.html)或[@GeneratedValue](http://docs.oracle.com)。 com/javaee/5/api/javax/persistence/GeneratedValue.html),即使在使用'.flush()'后,该字段仍会在'.save()'后返回为空。 – Doug 2017-10-04 13:14:00