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

Spring-Data JPA:保存引用现有实体的新实体

谷飞星
2023-03-14

问题与下面一个基本相同:

JPA级联、持久化和对分离实体的引用抛出PersistentObjectException。为什么?

我正在创建一个新实体,它引用一个现有的、分离的实体。现在,当我将这个实体保存到spring数据存储库中时,会抛出一个异常:

org.springframework.dao.InvalidDataAccessApiUsageException: detached entity passed to persist
public <S extends T> S save(S entity) {

    if (entityInformation.isNew(entity)) {
        em.persist(entity);
        return entity;
    } else {
        return em.merge(entity);
    }
}
public boolean isNew(T entity) {

    return getId(entity) == null;
}

编辑1:

注:

这个问题与如何在Spring JPA中保存引用现有实体的新实体没有直接关系?。为了详细说明,假设您收到了通过HTTP创建新实体的请求。然后从请求中提取信息,并创建您的实体和现有的引用实体。因此,他们将永远是超然的。

共有1个答案

田意致
2023-03-14

我也遇到过类似的问题,我试图保存一个新的实体对象,里面有一个已经保存的实体对象。

我所做的是实现persistable ,并相应地实现isNew()。

java prettyprint-override">public class MyEntity implements Persistable<Long> {

    public boolean isNew() {
        return null == getId() &&
            subEntity.getId() == null;
    }

当然,您也可以使用AbstractPersistable并重写isNew。

 类似资料:
  • 问题内容: 问题基本上与下面的问题相同: JPA级联仍然存在,对分离实体的引用将引发PersistentObjectException。为什么? 我正在创建一个引用现有的分离实体的新实体。现在,当我将此实体保存在spring数据存储库中时,会引发异常: 如果我们查看Spring数据JPA的源代码中的save()方法,则会看到: 如果我们看一下isNew() 因此,基本上,如果我保存()一个新实体,

  • 我有2个实体(我删除了无用的字段): 而且 这似乎符合我的情况(也是我当前的实现),但它不起作用。 我得到以下错误消息: 来自MySQL: 临时解决方案是从存储库中检索所有相应的权限(按permissionName搜索)。那么保存效果很好。逻辑上是正确的,但我希望有一个更简单的程序...

  • 我有两个实体 实体1 实体2 我对Jpa不是很熟悉,所以如果您需要对我的问题进行任何澄清,或者您需要任何更多的信息,请告诉我。

  • 我尝试读取ExcelFiles并将数据保存在postgres数据库中。在某些文件中,我会得到以下错误消息: null 在大多数已爬网的数据中,什么都没有发生。当我尝试保存semster对象时会出现错误。Excel文件的结构如下:标题、模块号、语言、学期号

  • Thread[hz._hzinstance_1_dev.partition-operation.thread-3,5,_hzinstance_1_dev]无法进行远程调用:com.hazelcast.collection.impl.collection.operations.CollectionAddOperation{serviceName='hz:impl:setService',identi

  • 问题内容: 我将SpringJPARepository与hibernate一起使用,并且对实体更新有一个问题。我通过传递单个实体来调用jparepository.save(entity),但在跟踪日志中,我也可以看到针对数据库中其他行发出的更新语句。在调用save之前,我有一个findAll并且某些实体的值正在更改。但是我只传递了一个要保存的实体,但是仍然保存了所有更新的实体。您能提供有关此信息吗

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