首页 > 解决方案 > 如果第二部分不起作用,Cypher 查询不会返回任何内容

问题描述

我有一个查询,它假设连接两个结果并将联合作为输出。

MATCH (:Some )-[r*0..1]-> (p:Address) WITH collect(p) AS rows1
MATCH (:Some2)-[r*0..1]-> (pp:Address) 
WITH  rows1+collect(pp) AS rows2 
UNWIND rows2 AS row RETURN  row

如您所见,选择有两个部分。因此,如果两个查询都有匹配的数据,但如果匹配的第二部分没有返回任何内容,那么它会返回空。含义MATCH (:Some2)-[r*0..1]-> (pp:Address) 返回空然后整个联合失败并返回 null 即使 MATCH (:Some )-[r*0..1]-> (p:Address)返回值。

如何解决这个问题?它是neo4j中的一个错误吗?

标签: neo4jcypher

解决方案


您实际上并没有问过一个问题(您确实只是描述了模式匹配的预期行为......即如果没有匹配就没有结果)......但我假设你想要一个解决方案?

MATCH (:Some )-[r*0..1]-> (p:Address)
RETURN p
UNION
MATCH (:Some2 )-[r*0..1]-> (p:Address)
RETURN p

应该做的伎俩。请注意,唯一重要的是返回的变量完全相同(它们包含的内容实际上并不重要)。

另外...您可能想看看OPTIONAL MATCH的作用...

希望这可以帮助。

问候,汤姆

更新

CALL apoc.cypher.run("
    MATCH (:Some )-[r*0..1]-> (p:Address)
    RETURN p
    UNION
    MATCH (:Some2 )-[r*0..1]-> (p:Address)
    RETURN p",{}) YIELD value
RETURN value.p AS result
ORDER BY result;

推荐阅读