关于这个问题,我检查了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;
}
}
讽刺的是,我没有访问这个特定的资源。我还有createdby
和modifiedby
的其他资源--是不是导致这个问题的资源?
我怀疑您的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引用。
在您的情况下,我认为您的Personentity
和Teamentity
都有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。为了能够搜索至少包含一个评论的“图书”,我已将“图书”设置为“评论”的父级,并且具有这样的路由。但是,我还需要找到撰写包含某些短语的评论的用户。 是否可以同时将书和用户作为评论的父级?有没有更好的方法来处理这种情况? 请注意,我无法更改数据建模的方式/不愿意这样做,因为数据已从持久性数据库传