我有一个数据集,我在这里作为示例表示:http://console.neo4j.org/?id=3dq78v http://console.neo4j.org/?id=3dq78v
我想要做的是对于图表中的每个 Z 节点(该示例只有一个,但我有很多),我想捕获一组属性,涵盖所有关联的 A、B、C 和 D 节点和关系。
我在尝试执行此操作时遇到了两个问题。第一个是 C 节点连接到 B 节点或 A 节点。其次,D 节点连接到 C 节点,但并不总是存在。
我希望输出一个看起来像这样的表:
Z.prop | A.道具| B. 道具 | (A-B 相对).prop | c.prop | (c-d rel).prop | d.prop
我尝试了很多使用 OPTIONAL MATCH 和使用WITH 的组合,但我无法得到它。我用 OPTIONAL MATCH 尝试过的所有操作都会找到该匹配(如果存在),然后不允许我维护与该可选匹配不匹配的项目(我意识到这就是它应该做的)。如果有帮助的话,我可以分享我尝试过的更具体的查询。
任何见解都会很棒!
编辑:使用版本 Neo4j 2.0.3
编辑:更新了控制台链接并进行了小修正
这是我尝试过的查询。我意识到为什么这不起作用,但也许您可以看到我的“逻辑”,我希望可选匹配在找到某些匹配项时不匹配时不删除节点。我想要那些不匹配和匹配的。
MATCH (z:Z)-[:has]->(a:A)
OPTIONAL MATCH (a)-[:has*1..2]->(c:C)
OPTIONAL MATCH (a)-[:has]->(b:B)-[:CONTAINS]->(c)
OPTIONAL MATCH (c)-[cd:knows]->(d:D)
RETURN z.name, a.name, b.name, c.name, d.name, cd.score;
编辑:我想做的是使用下面 4 个查询的结果,但使用 1 个查询获取结果
#1
MATCH (z:Z)-[:has]->(a:A)
MATCH (A)-[mr:has]->(b:B)-[:has]->(c:C)
MATCH (c)-[ds:knows]->(d:d)
RETURN a.name, b.name, mr.order, c.name, d.name, ds.score;
#2
MATCH (z:Z)-[:has]->(a:A)
MATCH (A)-[mr:has]->(b:B)-[:has]->(c:C)
WHERE NOT (c)-[:knows]->(:d)
RETURN a.name, mr.order, b.name, c.name;
#3
MATCH (z:Z)-[:has]->(a:A)
MATCH (A)-[:has]->(c:C)
WHERE NOT (c)-[:knows]->(:d)
RETURN a.name, c.name;
#4
MATCH (z:Z)-[:has]->(a:A)
MATCH (A)-[:has]->(c:C)
MATCH (c)-[ds:knows]->(d:d)
RETURN a.name, c.name, d.name, ds.score;
但这些并没有按照我预期的方式工作,因为有些结果。例如,我期望查询 3 仅返回:
A2 C4 d4 8
A2 C4 d5 6
A2 C4 d6 9
编辑-我的目标是精确输出:
a.name mr.order b.name c.name d.name d.score
A1 1 B3
A1 2 B1 C2
A1 2 B1 C5
A1 2 B1 C1 d1 1
A1 2 B1 C1 d3 4
A1 2 B1 C1 d2 3
A2 1 B4
A2 2 B2 C3
A2 C4 d4 8
A2 C4 d5 6
A2 C4 d6 9
这与我要查找的 11 行中的 9 行匹配,它错过了 B3 和 B4 的行
MATCH (z:Z)-[:has]->(a:A)
WITH a, z
MATCH (a)-[*1..2]-(c:C)
OPTIONAL MATCH (a)-[mr:has]->(b:B)-[:has]-(c:C)
WITH a, b, c, z, mr
OPTIONAL MATCH (c)-[cd:knows]->(d:d)
RETURN z.name, a.name, mr.order, b.name, c.name, d.name, cd.score;