SDN 4 - MappingException:无限递归(StackOverflowError)

时间:2015-07-05 16:27:30

标签: neo4j spring-data-neo4j spring-data-neo4j-4

我在执行存储库查询时遇到 org.neo4j.ogm.metadata.MappingException:无限递归(StackOverflowError)。该项目从SDN 3移植。

示例域模型:

@NodeEntity
public class Person {
    ...
    @Relationship(type = "FRIENDSHIP")
    private Set<Friendship> friendships = new HashSet<Friendship>();
    ...
}

@RelationshipEntity
public class Friendship {
    ...
    @StartNode private Person person1;
    @EndNode private Person person2;
    Date since;
    ...
}

运行以下查询时抛出异常:

@Query("MATCH (person1 {id: {0}.id})-[rel:FRIENDSHIP]->(person2 {id: {1}.id}) "
        + "return rel")
Friendship getFriendship(Person person1, Person person2);

例外:

org.neo4j.ogm.metadata.MappingException: Infinite recursion (StackOverflowError) (through reference chain: com.example.domain.Friendship["person1StartNode"]->com.example.domain.Person["friendships"]->java.util.HashSet[0]->com.example.domain.Friendship["niperson1StartNode"]->com.example.domain.Person["friendships"]......

我认为这可能与@StartNode和@EndNode属于同一类型有关。但是当@EndNode属于其他类型时,我得到了相同的异常。

使用快照。

2 个答案:

答案 0 :(得分:2)

我有同样的错误,但经过一些调查后,我注意到这是由于杰克逊将模型对象序列化为JSON,进入无限递归。

解决方案是在导致问题的成员上添加@JsonIgnore,或者只是从模型中填充DTO并将其返回到API层中。

我选择了第一个选项,因为我正在研究原型并需要快速迭代,但第二个选项带有一些BeanUtils魔法可以避免这种JsonIgnore的东西。

答案 1 :(得分:1)

请您将查询更改为

@Query("MATCH (person1 {id: {0}})-[rel:FRIENDSHIP]->(person2 {id: {1}}) "
        + "return rel")
Friendship getFriendship(long person1, long person2);

(或id的正确数据类型)

不支持实体本身的参数。

话虽如此,例外情况根本没有帮助。已打开https://jira.spring.io/browse/DATAGRAPH-694