我想使用CYPHER在AgensGraph上找到星形图案吗?
但是CYPHER模式仅呈现线性模式吗?
如何在AgensGraph上找到星形图案?
我想从查询中获得以下结果。
agens=# create (:v{id:1})-[:e]->(:v{id:2})-[:e]->(:v{id:3});
GRAPH WRITE (INSERT VERTEX 3, INSERT EDGE 2)
agens=# match (n:v{id:2}) create (n)-[:e]->(:v{id:4});
GRAPH WRITE (INSERT VERTEX 1, INSERT EDGE 1)
agens=# match some-pattern
agens-# return n1, r1, n2, r2, n3, r3, n4;
n1 | r1 | n2 | r2 | n3 | r3 | n4
-----------------+-------------------+-----------------+-------------------+-----------------+-------------------+-----------------
v[3.1]{"id": 1} | e[4.1][3.1,3.2]{} | v[3.2]{"id": 2} | e[4.2][3.2,3.3]{} | v[3.3]{"id": 3} | e[4.3][3.2,3.4]{} | v[3.4]{"id": 4}
(1 row)
答案 0 :(得分:0)
您可以使用变量搜索星型。
首先,在第一个匹配项上写下线性图案。
并在下一场比赛中使用变量添加新模式。
agens=# match (n1:v{id:1})-[r1:e]->(n2:v{id:2})-[r2:e]->(n3:v{id:3})
agens-# match (n2)-[r3:e]->(n4:v{id:4})
agens-# return n1, r1, n2, r2, n3, r3, n4;
n1 | r1 | n2 | r2 | n3 | r3 | n4
-----------------+-------------------+-----------------+-------------------+-----------------+-------------------+-----------------
v[3.1]{"id": 1} | e[4.1][3.1,3.2]{} | v[3.2]{"id": 2} | e[4.2][3.2,3.3]{} | v[3.3]{"id": 3} | e[4.3][3.2,3.4]{} | v[3.4]{"id": 4}
(1 row)