java–Spring Data JPA JpaRepository.save(实体)不返回数据库默认值

java–Spring Data JPA JpaRepository.save(实体)不返回数据库默认值,第1张

概述我有一个相当简单的问题.在单个事务中,我的代码看起来像这样:MyClass c = new MyClass(); c.setPropA('A'); c = myClassRepository.save(c); c.setPropC('C'); 我的实体看起来像这样:@Entity @Table(name = 'MY_CLASS') public clas

我有一个相当简单的问题.在单个事务中,我的代码看起来像这样:

MyClass c = new MyClass();c.setPropA("A");c = myClassRepository.save(c);c.setPropC("C");@H_502_8@

我的实体看起来像这样:

@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; }}@H_502_8@

并且数据库设置如下(Dialect = Oracle 11G)

CREATE table MY_CLASS {  PROP_A VARCHAR2 NOT NulL PRIMARY KEY,PROP_B VARCHAR2 DEFAulT 'B' NOT NulL,PROP_C VARCHAR2}@H_502_8@

所以,根据持久化实体的代码,我认为我会得到类似这样的查询:

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"@H_502_8@

……但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这样做. 总结

以上是内存溢出为你收集整理的java – Spring Data JPA JpaRepository.save(实体)不返回数据库默认值全部内容,希望文章能够帮你解决java – Spring Data JPA JpaRepository.save(实体)不返回数据库默认值所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1267240.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存