存在一个具有多个级别的neo4j图。我想首先检索一个节点及其第一级节点,然后在检索所有第一级节点之后,再检索第二级节点。
我编写了以下查询。
match(node{name:'some name'})-[r1]-(a)
optional match(a)-[r2]-(b)
return node,a,b但上面的查询将首先匹配第一级节点,如果给定节点与第二级节点连接,则它将检索所有第二级连接的节点,然后再次到达第一级节点并继续该过程。(深度优先方法)。
我需要它像广度优先的方法那样做。
发布于 2015-03-04 19:02:57
您的语言意味着您对我来说有某种层次结构,并且您可能希望为您的查询添加方向。您要做的另一件事是使用with语句获取第一个查询的结果,并将其用作第二个查询的起点。在第二个查询中使用方向是导入的,因为如果没有它,您首先匹配的a节点将与原始开始节点相匹配。coalesce函数只处理a没有子级的实例。
match (start {name : 'some name'})-->(a)
with a
optional match a-->b
return a, coalesce(null, 'no child')https://stackoverflow.com/questions/28848760
复制相似问题