Neo4j/Cypher: All paths between two nodes with a relationship property filter

解决方案一

I am trying to perform a query to retrieve all paths between two nodes a and b in which all the paths there is a relationship property fulfilled.

I have tried in many ways but I am not able to success.

MATCH p=(o{value:"a"})-[r*]-(x{value:"b"}) where has(r.property) and r.property="foo" return p

relationship part i have changed to [r*..] and many other options but not working

The function shortestpath does not help me because I want not only the shortest but all the possibilities.

Can someone help me or tell me which is the error in the query?

Thank you in advance.

解决方案二

What you're looking for is the ALL predicate on the relationships collection of the path :

MATCH p=(o{value:"a"})-[r*]-(x{value:"b"})
WHERE ALL(x IN rels(p) WHERE x.property = "foo")
RETURN p

And please use labels !

原文地址:https://*.com/questions/39287874/neo4j-cypher-all-paths-between-two-nodes-with-a-relationship-property-filter?rq=1

上一篇:阿里云发布边缘节点服务2.0,建立“融合、开放、联动”的边缘计算新形态


下一篇:SQL Server:时间范围查询重叠