如何解决Neo4j:如何返回具有共同特定节点的节点?
我想知道如何返回所有带有 Label_C
的节点,这些节点至少有一个带有 LABEL_A
的节点,如果连接到带有 LABEL_A
的节点的输出节点的数量大于或等于阈值。因此,可以通过来自任何所需输出节点的路径到达目标节点。
结构是(common:Label_A)-[:REL_1]->(:LABEL_B)<-[:REL_2]-(output:Label_C)
我的尝试:
MATCH (common:Label_A)-[:REL_1]->(:LABEL_B)<-[:REL_2]-(output:Label_C)
WITH DISTINCT common,output,count(id(common)) AS cnt WHERE cnt >= [THRESHOLD]
RETURN DISTINCT output
解决方法
使用大小,您可以像这样构建查询:
MATCH (common:Label_A) WHERE size((common)--(:Label_B)--(:Label_C)) > 3
WITH common
MATCH (common)--(:Label_B)--(output:Label_C)
RETURN DISTINCT output
其中 3 可以替换为您的实际阈值。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。