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

Spring Data REST:检测到多个关联链接具有相同的关系类型

符风畔
2023-03-14

关于这个问题,我检查了Spring Data Rest Ambiguous Association Exception,但无法让它为我工作。

正如您在下面的代码中看到的,我添加了@restresource注释,其中rel等于其他值。

与上面的问题类似,POST请求起作用,但GET请求引发关于具有相同关系类型的多个关联链接的异常:

“无法写入JSON:检测到多个具有相同关系类型的关联链接!DisambiguateAssociation@org.springframework.data.rest.core.annotation.restResource(Rel=createdby,exported=true,path=,description=@org.springframework.data.rest.core.annotation.description(value=))@javax.persistence.ManyToOne(optional=true,targetentity=void,cascade=[],关系类型相同的链接!消除关联@org.springframework.data.rest.core.annotation.restResource(rel=createdby,exported=true,path=,description=@org.springframework.data.rest.core.annotation.description=@org.springframework.data.rest.core.annotation.description(value=))@javax.persistence.manytoOne(optional=true,targetentity=void,cascade=[],(通过引用链:org.springframework.hateoas.pagedresources[\“_embedded\”]->java.util.UnmodifiableMap[\“Persons\”]->java.util.ArrayList[0])“

错误似乎发生在这个类中:

@Entity
@Table(name = "team")
public class TeamEntity extends AssignableEntity {
    private String name;
    private LocalDateTime createdDate;
    private LocalDateTime modifiedDate;
    private Collection<MembershipEntity> memberships;
    private PersonEntity createdBy;
    private PersonEntity modifiedBy;

    @Basic
    @Column(name = "NAME")
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Basic
    @Column(name = "CREATED_DATE")
    public LocalDateTime getCreatedDate() {
        return createdDate;
    }

    html" target="_blank">public void setCreatedDate(LocalDateTime createdDate) {
        this.createdDate = createdDate;
    }

    @Basic
    @Column(name = "MODIFIED_DATE")
    public LocalDateTime getModifiedDate() {
        return modifiedDate;
    }

    public void setModifiedDate(LocalDateTime modifiedDate) {
        this.modifiedDate = modifiedDate;
    }

    @OneToMany(mappedBy = "team")
    public Collection<MembershipEntity> getMemberships() {
        return memberships;
    }

    public void setMemberships(Collection<MembershipEntity> memberships) {
        this.memberships = memberships;
    }

    @RestResource(rel = "team_createdBy")
    @ManyToOne
    @JoinColumn(name = "CREATED_BY", referencedColumnName = "ASSIGNABLE_ID", nullable = false)
    public PersonEntity getCreatedBy() {
        return createdBy;
    }

    public void setCreatedBy(PersonEntity createdBy) {
        this.createdBy = createdBy;
    }

    @RestResource(rel = "team_modifiedBy")
    @ManyToOne
    @JoinColumn(name = "MODIFIED_BY", referencedColumnName = "ASSIGNABLE_ID", nullable = false)
    public PersonEntity getModifiedBy() {
        return modifiedBy;
    }

    public void setModifiedBy(PersonEntity modifiedBy) {
        this.modifiedBy = modifiedBy;
    }
}

讽刺的是,我没有访问这个特定的资源。我还有createdbymodifiedby的其他资源--是不是导致这个问题的资源?

共有1个答案

那宏大
2023-03-14

我怀疑您的Personentity对象上可能有export=false。因此,personentity中的任何引用都将添加到teamentity_links部分。因为这两个Personentity对象都有一个CreatedBy引用,所以它们与Teamentity.CreatedBy引用冲突。

为了理解正在发生的事情,以下示例可能会有所帮助:

class Answer {
   Question q; //JPA ManyToOne back-reference
}

class Question {
   List<Answer> as; // JPA OneToMany reference
}

class UserAnswer {
   Answer a;
   Question q;
}

在我的示例中,因为答案只能存在于问题中,所以我们在AnswerResource上有以下内容,以防止导出答案:

@RestResource(exported = false)

这导致应答对象在父对象中序列化,而不是作为_links部分中的引用,这最终是问题的原因....

序列化userAnswer时,它呈现如下内容:

{
  "answer" : {
    "creationDate" : "2014-09-18T17:28:31.000+0000",
    "modificationDate" : "2014-09-18T17:28:31.000+0000",
    "answerText" : "Vendas",
  },
  "_links" : {
    "self" : {
      "href" : "http://localhost:9090/data/userAnswers/15"
    },
    "question" : {
      "href" : "http://localhost:9090/data/userAnswers/15/question"
    }
  }
}

请注意,上面的“_links.question”来自答案

因此,如果您将问题添加用户应答中,您将看到您询问的错误,因为用户应答本身也希望包含对问题的_link引用。

在您的情况下,我认为您的PersonentityTeamentity都有createdby引用。

我还不能100%确定解决方案是什么,我不知道您是否可以指定分层rel名称。

 类似资料:
  • 问题内容: 我正在尝试做一个简单的Spring应用程序。它需要公开REST端点并将其保存到关系数据库中。 我接受了您的示例项目http://spring.io/guides/gs/accessing-data- rest/ 。如您的指南中所述,我能够执行所有操作(POST,PATCH,PUT,GET)。 但是,我尝试为Person Entity类添加关系,事情开始崩溃。 呼叫: 问题1:我可以发表

  • 我正在尝试做一个简单的Spring应用程序。它需要公开RESTendpoint并将其保存到关系数据库中。 我拿了你的样本项目,http://spring.io/guides/gs/accessing-data-rest/.我能够完成您指南中提到的所有操作(POST、PATCH、PUT、GET)。 然而,我试着在Person-Entity类中添加关系,结果开始崩溃。 电话: 问题1:我能写一篇文章,

  • 问题内容: 我有以下查询。它工作正常,但我需要从另一个名为FB的表中提取BUserName,该表具有与FU表中的UserID相关的UserID字段。这可能吗? 只是为了澄清。我在FB表中没有UserName列。它确实有FB.UserID,它与FF.UserID有关系,这是我要从中提取第二个UserName的地方。因此,通过这种关系,我试图从与FB表中的userID相关的FF.UserID表中拉出用

  • 问题内容: 有一个实体类“ A”。A类可能具有相同类型“ A”的子级。如果“ A”是孩子,则也应保留它的父母。 这可能吗?如果是这样,我应该如何在Entity类中映射关系?[“ A”有一个id列。] 问题答案: 是的,这是可能的。这是标准双向@ManyToOne/ @OneToMany关系的特例。之所以特别是因为关系两端的实体都是相同的。JPA 2.0规范的第2.10.2节详细介绍了一般情况。 这

  • 我需要支持一个涉及以下实体的场景(使用JPA): 用户 一个用户可以有多个帐户,一个帐户可以在多个用户之间共享,这是迄今为止的标准@ManyToMany关系。 一个用户可以为每个帐户拥有一组不同的角色,一个角色可以在多个用户之间共享。 我遵循了这个实践,它解释了一种用额外列映射多对多关联的方法,但我不确定我是否得到了它。 用户实体: 账户实体: 用户帐户实体: 用户帐号: 我正在创建一个新用户并尝

  • 问题内容: Book,User和Review说,我正在构建具有复杂模型的应用程序。 评论包含书籍和用户ID。为了能够搜索至少包含一个评论的“图书”,我已将“图书”设置为“评论”的父级,并且具有这样的路由。但是,我还需要找到撰写包含某些短语的评论的用户。 是否可以同时将书和用户作为评论的父级?有没有更好的方法来处理这种情况? 请注意,我无法更改数据建模的方式/不愿意这样做,因为数据已从持久性数据库传