|| apoc.agg.nth - APOC 核心文档 - Neo4j 文档

apoc.agg.nth

详情

语法

apoc.agg.nth(value, offset)

描述

返回给定集合中的第 n 个值(要获取未知长度集合的最后一个项,可以使用 -1)。

参数

名称

类型

描述

value

任意

要聚合的值。

offset

整数

要返回的值的索引,或 -1 表示返回最后一项。

返回

任意

使用示例

本节中的示例基于以下示例图

CREATE (Keanu:Person {name:'Keanu Reeves', born:1964})
CREATE (TomH:Person {name:'Tom Hanks', born:1956})

CREATE (TheMatrix:Movie {title:'The Matrix', released:1999, tagline:'Welcome to the Real World'})
CREATE (TheMatrixReloaded:Movie {title:'The Matrix Reloaded', released:2003, tagline:'Free your mind'})
CREATE (TheMatrixRevolutions:Movie {title:'The Matrix Revolutions', released:2003, tagline:'Everything that has a beginning has an end'})
CREATE (YouveGotMail:Movie {title:"You've Got Mail", released:1998, tagline:'At odds in life... in love on-line.'})
CREATE (SleeplessInSeattle:Movie {title:'Sleepless in Seattle', released:1993, tagline:'What if someone you never met, someone you never saw, someone you never knew was the only someone for you?'})

CREATE (Keanu)-[:ACTED_IN {roles:['Neo']}]->(TheMatrix)
CREATE (Keanu)-[:ACTED_IN {roles:['Neo']}]->(TheMatrixReloaded)
CREATE (Keanu)-[:ACTED_IN {roles:['Neo']}]->(TheMatrixRevolutions)

CREATE (TomH)-[:ACTED_IN {roles:['Joe Fox']}]->(YouveGotMail)
CREATE (TomH)-[:ACTED_IN {roles:['Sam Baldwin']}]->(SleeplessInSeattle);
apoc.agg.nth
MATCH (p:Person)-[:ACTED_IN]->(movie)
WITH p, movie
ORDER BY p, movie.released
RETURN p.name AS person, apoc.agg.nth(movie, 1) AS nthMovie
使用 Cypher 的 OFFSET 和 LIMIT
MATCH (p:Person)
CALL (p) {
  MATCH (p)-[:ACTED_IN]->(movie)
  RETURN movie ORDER BY p, movie.released OFFSET 1 LIMIT 1
}
RETURN p.name AS person, movie AS nthMovie
结果
人物 第N部电影

"基努·里维斯"

(:Movie {tagline: "解放你的思想", title: "黑客帝国2:重装上阵", released: 2003})

"汤姆·汉克斯"

(:Movie {tagline: "生活中对立…​ 网络中相爱。", title: "电子情书", released: 1998})

© . This site is unofficial and not affiliated with Neo4j, Inc.