java jpa save,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仍在ORA-01407: cannot update ("MY_SCHEMA"."MY_CLASS"."PROP_B") to NULL,因此会中断。我得到一个@PrePersist堆栈跟踪。

我意识到有很多方法可以使用columnDefinition或在Java中设置org.hibernate.Session.saveOrUpdate()上的默认值,但我不必复制默认值。

注意:在我使用{{1}}而不是Spring Data JPA进行此操作之前,这个工作正常。

提前感谢您的帮助!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值