如何在Neo4j Cypher中获得与给定属性具有给定量的传出关系的节点?

Mar*_*ace 3 neo4j nosql graph-databases cypher

在我的域中,节点可以具有与其他实体相同类型的多个关系.每个关系都有几个属性,我想检索由至少2个呈现给定属性的关系连接的节点.

EG:节点之间的关系具有属性year.如何找到与year设置至少有两个传出关系的节点2012

Chypher到目前为止为什么查询看起来像这样(语法错误)

START x = node(*)
MATCH x-[r:RELATIONSHIP_TYPE]->y
WITH COUNT(r.year == 2012) AS years
WHERE HAS(r.year) AND years > 1
RETURN x;
Run Code Online (Sandbox Code Playgroud)

我也试过嵌套查询,但我相信这是不允许的Cypher.最接近的是以下但我不知道如何摆脱值为1的节点:

START n = node(*)
MATCH n-[r:RELATIONSHIP_TYPE]->c
WHERE HAS(r.year) AND r.year == 2012
RETURN n, COUNT(r) AS counter
ORDER BY counter DESC
Run Code Online (Sandbox Code Playgroud)

Wer*_*rås 5

试试这个查询

START n = node(*)
MATCH n-[r:RELATIONSHIP_TYPE]->c
WHERE HAS(r.year) AND r.year=2012
WITH n, COUNT(r) AS rc
WHERE rc > 1
RETURN n, rc
Run Code Online (Sandbox Code Playgroud)