当前位置: 首页 > 知识库问答 >
问题:

Spring Data JPA JPA是一个预测。保存(实体)不返回数据库默认值

林修真
2023-03-14

我有一个相当简单的问题。在单个事务中,我的代码如下所示:

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

数据库是这样设置的(方言=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永远不会发生。为什么实体没有刷新?

这是因为INSERT之后(立即)出现了更新,而c.propB仍然是null。我得到一个ORA-01407:无法将(“我的_模式”、“我的_类”、“PROP_B”)更新为NULL堆栈跟踪。

我意识到有很多方法可以解决这个问题,比如在Java中使用@PrePersist或者在columnDefinition上设置默认值,但我不应该重复默认值。

注意:这在我之前使用org时是有效的。冬眠一场saveOrUpdate()而不是Spring Data JPA,用于此操作。

提前感谢任何帮助!


共有1个答案

国言
2023-03-14

Hibernate不知道B是由数据库生成的,并且它必须在插入后读取它,除非您使用@Generated注释告诉它这样做。

 类似资料:
  • 我有一个非常令人困惑的问题,就是占用了很多时间: 这段代码的时间戳是在my Postgres DB中设置的,但存储库返回一个created=null的实体; 我尝试过一些注释,比如: @产生 来源:Spring Data JPA JPA Propository。保存(实体)不返回数据库默认值 但对我来说什么都不管用。

  • 问题内容: 我有一个很简单的问题。在单个事务中,我的代码如下所示: 我的实体看起来像这样: 像这样建立数据库(Dialect = Oracle 11G) 因此,基于持久化实体的代码,我认为我会得到如下所示的查询: …但是永远不会发生。为什么实体没有刷新? 由于(立即)跟随和仍然而中断了该操作。我得到一个堆栈跟踪。 我意识到有很多方法可以在Java中使用或设置默认值,但是我不必重复默认值。 注意:这

  • 我是Hibernate的新手,并要求使用具有这些列的表的数据库 表:TBL _ product//库存项目列表< br >列:< br > key _ product < br > key _ category < br > fld _ product _ name < br > fld _ Inventory _ qty < br > fld _ unit _ price < br > fld

  • 我有一个问题,Spring数据没有保存实体。应用程序逻辑如下: 另一个应用程序正在监听负载相当重的Kafka主题(每秒数十条消息)并将消息插入数据库中具有“NEW”状态的表中。 @调度方法加载一个具有“NEW”状态的实体列表,这些实体被一个接一个地传输到FixedThreadPool(20个线程),它们的状态设置为“PROCESSING”和一个saveAll方法调用同一个表。 这两种日志方法都显示

  • 我在使用JPA时遇到了一些困难。我没有得到任何异常,但我不能保存任何东西到数据库。我从Hibernate到Jpa,在那里一切都工作得很好。下面是我的文件 Application.Properties: 存储库: 服务: 我在提交表单时得到了200的响应,但在数据库中找不到数据

  • 我有一个使用JPA的Spring Boot应用程序,它有两个数据源,一个用于DB2,一个用于SQL Server。 当我尝试将实体保存到SQL Server时,不会抛出任何错误,但该实体不会持久化到数据库。我看不到日志中正在生成插入。 提前感谢 下面是我尝试保存实体所执行的代码@组成部分 下面是sql Server配置。 这是SQL Server存储库 公共接口BeercupMessageLogR