gpt4 book ai didi

nosql - 如何获取与 Neo4j Cypher 中的给定属性具有给定数量的传出关系的节点?

转载 作者:行者123 更新时间:2023-12-01 11:48:26 24 4
gpt4 key购买 nike

在我的域中,一个节点可以与其他实体具有多个相同类型的关系。每个关系都有几个属性,我想检索由至少 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;

我也试过嵌套查询,但我相信这在 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

最佳答案

试试这个查询

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

关于nosql - 如何获取与 Neo4j Cypher 中的给定属性具有给定数量的传出关系的节点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13751183/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com