我不是 Cypher 的专家,但我在一个项目中,我有几个具有以下属性的节点:
['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
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句