我有一个相当简单的问题.在单个事务中,我的代码看起来像这样:
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,因此会中断.我得到一个ORA-01407:无法更新(“MY_SCHEMA”.“MY_CLASS”.“PROP_B”)到NULL堆栈跟踪.
我知道有很多方法可以使用@PrePersist或在Java中的columnDefinition上设置默认值,但我不应该重复默认值.
注意:这在我使用org.hibernate.Session.saveOrUpdate()而不是Spring Data JPA进行此操作之前有效.
在此先感谢您的帮助!
最佳答案
Hibernate不知道B是由数据库生成的,并且它必须在插入后读取它,除非你告诉它使用
@Generated
annotation这样做.版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。