[英]How to get all nodes in a disjointed sub-graph - neo4j / py2neo
如果我有一个neo4j数据库,我想查询以获取一个特定的脱节子图中的所有节点。 (在py2neo或cypher中)
如果我有节点组,则每个组中的节点按该组内的关系连接,但不在组之间连接。 我可以查询一个节点并获取该节点组中的所有节点吗?
[更新]
如果通过“节点组”表示“不相交的子图”,则以下是如何获取包含特定节点(例如, Neo
节点)的不相交子图(具有任何类型的关系)中的所有节点:
MATCH (n { name: "Neo" })
OPTIONAL MATCH p=(n)-[*]-(m)
RETURN REDUCE(s = [n], x IN COLLECT(NODES(p)) |
REDUCE(t = s, y IN x | CASE WHEN y IN t THEN t ELSE t + y END )) AS nodes;
此查询使用OPTIONAL MATCH
查找与Neo
节点“相关”的节点,因此如果该节点没有关系,则查询仍然可以返回结果。
两个(嵌套的) REDUCE
子句确保返回的集合只有不同的节点。
外部REDUCE
子句使用n
节点初始化结果集合,因为它必须始终位于不相交的子图中,即使没有其他节点也是如此。
MATCH p=(n { name: "Neo" })-[r*0..]-(m)
WITH NODES(p) AS nodes
UNWIND nodes AS node
RETURN DISTINCT node
这个更简单的查询(返回节点行)使用[r*0..]
来允许0长度路径(即, n
不需要任何关系 - 并且m
可以与n
相同)。 它使用UNWIND
将nodes
节点集合转换为行,然后使用DISTINCT
消除重复。
下面的这个替代解决方案(返回节点行)也应该有效,除了当前存在一个错误( 我刚刚报告 )导致在查询解除NULL
之后忘记所有标识符(例如,如果OPTIONAL MATCH
无法找到匹配)。 由于此错误,如果Neo
节点没有关系,则下面的查询当前不返回任何结果。 因此,您必须使用上面的查询,直到修复错误。
MATCH (n { name: "Neo" })
OPTIONAL MATCH p=(n)-[*]-(m)
WITH n, NODES(p) AS nodes
UNWIND nodes AS node
RETURN DISTINCT (
CASE
WHEN node IS NULL THEN n
ELSE node END ) AS res;
如果您添加了图表或一些示例数据,它可能会有所帮助。 但是,如果我正确理解您的数据模型,那么您将节点的“组”定义为通过某种关系连接的所有节点? 因此,要获取“group1”节点的所有成员(让我们将其定义为通过group1关系连接的所有节点)而不是任何连接到group2的节点,您可以使用如下查询:
MATCH (a:Person)-[:GROUP1]-(b:Person)
WHERE NOT exists((a)-[:GROUP2]-())
RETURN a
您还可以使用节点标签来定义节点组。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.