我的关系图如下图所示
使用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