Cypher路径查询如何避免重复


在Neo4j中,Cypher是一种用于查询图形数据库的语言。当执行路径查询时,可能会出现重复的结果。为了避免这种情况,可以使用DISTINCT关键字来确保查询结果中的每个节点和关系都是唯一的。

以下是一个使用DISTINCT关键字的Cypher路径查询示例:

MATCH (a)-[*]->(b)WHERE a.name = "start" AND b.name = "end"RETURN DISTINCT a, b, path

在这个示例中,我们查询从名为"start"的节点到名为"end"的节点的所有路径。通过在RETURN子句中使用DISTINCT关键字,我们可以确保返回的每个节点和关系都是唯一的。

如果你想要避免重复的路径,而不是节点和关系,可以使用COLLECTDISTINCT组合:

MATCH (a)-[*]->(b)WHERE a.name = "start" AND b.name = "end"RETURN DISTINCT COLLECT(path) as unique_paths

在这个示例中,我们使用COLLECT函数收集所有从"start"到"end"的路径,然后使用DISTINCT关键字确保返回的路径集合中没有重复。


上一篇:Neo4j数据模型能修改吗

下一篇:Neo4j数据模型能定时吗


Cypher
Copyright © 2002-2019 测速网 www.inhv.cn 皖ICP备2023010105号
测速城市 测速地区 测速街道 网速测试城市 网速测试地区 网速测试街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!

热门搜索 城市网站建设 地区网站制作 街道网页设计 大写数字 热点城市 热点地区 热点街道 热点时间 房贷计算器