首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Neo4j:首先检索所有一级节点,然后检索二级节点

Neo4j:首先检索所有一级节点,然后检索二级节点
EN

Stack Overflow用户
提问于 2015-03-04 15:28:32
回答 1查看 680关注 0票数 0

存在一个具有多个级别的neo4j图。我想首先检索一个节点及其第一级节点,然后在检索所有第一级节点之后,再检索第二级节点。

我编写了以下查询。

代码语言:javascript
复制
match(node{name:'some name'})-[r1]-(a)

optional match(a)-[r2]-(b)

return node,a,b

但上面的查询将首先匹配第一级节点,如果给定节点与第二级节点连接,则它将检索所有第二级连接的节点,然后再次到达第一级节点并继续该过程。(深度优先方法)。

我需要它像广度优先的方法那样做。

EN

回答 1

Stack Overflow用户

发布于 2015-03-04 19:02:57

您的语言意味着您对我来说有某种层次结构,并且您可能希望为您的查询添加方向。您要做的另一件事是使用with语句获取第一个查询的结果,并将其用作第二个查询的起点。在第二个查询中使用方向是导入的,因为如果没有它,您首先匹配的a节点将与原始开始节点相匹配。coalesce函数只处理a没有子级的实例。

代码语言:javascript
复制
match (start {name : 'some name'})-->(a)
with a
optional match a-->b
return a, coalesce(null, 'no child')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28848760

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档