We can use patterns to search a subgraph like this:
MATCH(a:Person{id:1})-[:Knows*1..]->(b:Person)
However, I find it takes too long when the subgraph is large. Therefore I use apoc procedure:
MATCH(a:Person{id:1})
CALL apoc.path.subgraphNodes(p,{
relationshipFilter: "Knows>",
minLevel:1
})
YIELD node
return node.name as name.
It runs much faster ! The minLevel of the node is 1. The thing is I want to get the actual level of each node returned.
Anyone can help me? Thanks!