如何找到 2nd 度朋友与 Spring Data 之间的关系 neo4j.



我的关系图如下图所示
使用MATCH (n:Person {name:'1'})-[]-()-[r]-(m) RETURN m,r会返回"4"和"5",但无法得到"4"和"5"之间的关系,实际上,"4"跟着"5","r"只是代表4(4-->2(和5(5-->3(的朋友。
在春季数据 neo4j
域中.java

@NodeEntity(label = "Person")
public class PersonTest {
@Id
private Long id;
@Property(name = "name")
private String name;
@Relationship(type = "Follow")  //direction=Relationship.DIRECTION
private List<PersonTest> friends;

存储库.java

public interface PersonRepository extends Neo4jRepository<PersonTest,Long> {
@Query("MATCH (n:Person {name:{name}})-[]-()-[r]-(m) RETURN m,r")
Collection<PersonTest> graph(@Param("name") String name);
}

服务.java

Collection<PersonTest> persons = personRepository.graph(name);
Iterator<PersonTest> result = persons.iterator();
while (result.hasNext()) {
for (PersonTest friend : p.getFriends()) {
//........here will get 2 and 3!
}
}

如何解决这个问题??获取"4"和"5"之间的关系。

要查找某个级别的相关子项,可以使用可变长度的双面模式:

MATCH (n:Person {name:'1'})-[:Follow*2]->(m)-[r:Follow]-()<-[:Follow*2]-(n) 
RETURN m,r

http://console.neo4j.org/r/el2x80

更新。我认为这是一个更正确的查询:

MATCH (n:Person {name:'1'})-[:Follow*2]->(m:Person)-[r:Follow]-(k:Person) 
WHERE (n)-[:Follow*2]->(k) 
RETURN m, r

http://console.neo4j.org/r/bv2u8k

最新更新