neo4j - 从 Neo4j Cypher allShortestPaths() 中排除包含给定节点或给定关系的路径

标签 neo4j cypher shortest-path

给定以下 Neo4j Cypher 查询,返回的路径集合不包含任何包含 itemId 等于“Q5”的 Item 节点的路径的最佳方法是什么?

MATCH p=allShortestPaths( (a:Item {itemId:"Q6294"})-[*]-(b:Item {itemId:"Q359442"}) ) 
RETURN p;

此外,在给定上述查询的情况下,返回的路径集合最好的方法是什么,不包含任何包含 propId 等于“P31”的关系的路径?

谢谢, 詹姆斯·韦弗

最佳答案

  1. 返回的路径集合不包含任何包含itemId等于“Q5”的Item节点的路径:

    MATCH p=allShortestPaths( (a:Item {itemId:"Q6294"})-[*]-(b:Item {itemId:"Q359442"}) )
    WHERE NONE(x IN NODES(p) WHERE x:Item AND x.itemId = "Q5")
    RETURN p;
    
  2. 返回的路径集合不包含任何包含 propId 等于“P31”的关系的路径:

    MATCH p=allShortestPaths( (a:Item {itemId:"Q6294"})-[*]-(b:Item {itemId:"Q359442"}) )
    WHERE NONE(x IN RELATIONSHIPS(p) WHERE x.propId = "P31")
    RETURN p;
    

关于neo4j - 从 Neo4j Cypher allShortestPaths() 中排除包含给定节点或给定关系的路径,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35662955/

相关文章:

neo4j - 快速查询上的三元组与 native 图数据库

Neo4j cypher如何在第一次匹配时停止递归

neo4j - 如何删除 Neo4j 中节点上的标签?

algorithm - 只有两种可能成本的完整图。从 0 到 N - 1 的最短路径成本是多少

neo4j - 如何配置 Neo4j 浏览器以使用自定义 REST 端点?

neo4j - Cypher 查询 Neo4j ForEach 合并返回?

ruby-on-rails - Neo4j.rb 创建独特的关系

rest - 创建工作正常,但 neo4j post params 中的 MERGE 有错误

algorithm - 如何使用A*算法找到所有最短路径?

c++ - 使用 Boost Dijkstra 和指定的 MAX DISTANCE 查找最短路径