如何在 Neo4j 中找到具有多个节点和多个关系的最短路径



我不是密码专家,但我在一个项目中,我有几个具有以下属性的节点:

['COGAB11', 'COGAB7', 'COGAB30', 'COGAB32', 'COGAB94', 'COGAB70',
'COGAB01', 'COGAB04', 'COGAB91', 'COG1AB77', 'COGAB46', 'COGAB40',
'COGAB31', 'COGAB14']

它们之间有几种关系:

[rel:coexpression|cooccurence|database|experimental|
fusion|neighborhood|score|textmining]

它还有一个像score这样的属性,它是一个 0-1000 的数字整数值,我想找到所有这些节点之间的最短路径,并获得它们之间分数大于和等于 500 的关系。因此,我想返回包含这些关系和路径的图形。但是,我只找到了最短路径的查询,但在两个节点之间,而不是在多个节点和多个关系之间。此外,我不确定我是否应该为此使用 APOC。

MATCH (start:Loc{name:'A'}), (end:Loc{name:'F'})
CALL algo.shortestPath.stream(start, end, 'cost')
YIELD nodeId, cost
RETURN algo.asNode(nodeId).name AS name, cost

如果你的意思是希望每个关系都有score>= 500,那么这应该返回最短路径:

MATCH (start:Loc {name: 'A'}), (end:Loc {name: 'F'}),
p = SHORTESTPATH((start)-[:coexpression|cooccurence|database|experimental|fusion|neighborhood|score|textmining]-(end))
WHERE ALL(r IN RELATIONSHIPS(p) WHERE r.score >= 500)
RETURN p

相关内容

  • 没有找到相关文章

最新更新