在 Neo4j 中,FOREACH
语句用于在查询中对一组元素执行某些操作,通常是在创建或更新节点关系时。它常常与 CREATE
或 SET
等操作结合使用。
创建多个关系:
sql
MATCH (p:Person), (m:Movie)
WHERE p.name = 'Alice' AND m.title = 'The Matrix'
FOREACH (ignoredVar IN CASE WHEN NOT EXISTS((p)-[:ACTED_IN]->(m)) THEN [1] ELSE [] END |
CREATE (p)-[:ACTED_IN]->(m));
这个查询会找到名为 "Alice" 的节点和名为 "The Matrix" 的电影,并且只在尚不存在 "ACTED_IN" 关系的情况下创建关系。
批量更新节点属性:
sql
MATCH (p:Person)
WHERE p.age < 30
FOREACH (person IN [p] | SET person.isYoung = true);
这个查询会找到年龄小于 30 的所有节点,并为每个节点设置 "isYoung" 属性为 true。
根据列表创建关系:
sql
MATCH (p:Person), (m:Movie)
WHERE p.name = 'Bob' AND m.title = 'The Matrix'
FOREACH (rating IN [4, 5, 3] |
CREATE (p)-[:RATED {rating: rating}]->(m));
这个查询的目的是在已经存在的节点 "Bob" 和 "The Matrix" 之间创建多个 "RATED" 关系,每个关系都有一个不同的评分属性。以下是查询的解释:
-
MATCH (p:Person), (m:Movie)
:这一部分使用MATCH
语句找到满足条件的 "Person" 节点和 "Movie" 节点。其中,(p:Person)
表示一个 "Person" 节点,(m:Movie)
表示一个 "Movie" 节点。 -
WHERE p.name = 'Bob' AND m.title = 'The Matrix'
:这一部分使用WHERE
语句过滤出 "Person" 节点的名字为 "Bob",且 "Movie" 节点的标题为 "The Matrix"。 -
FOREACH (rating IN [4, 5, 3] | CREATE (p)-[:RATED {rating: rating}]->(m))
:这一部分使用FOREACH
语句对之前匹配的节点执行批处理操作。对于每个评分值rating
(在列表[4, 5, 3]
中迭代),都会执行一次下面的操作:CREATE (p)-[:RATED {rating: rating}]->(m)
:在 "Bob" 节点和 "The Matrix" 节点之间创建一个 "RATED" 关系,关系上带有一个 "rating" 属性,该属性的值是当前迭代的评分值。
综合起来,这个查询会创建多个 "RATED" 关系,每个关系都表示 "Bob" 对 "The Matrix" 的不同评分。例如,会创建三个关系,分别表示评分为 4、5 和 3。
条件更新属性:
sql
MATCH (p:Person)
WHERE p.name = 'Charlie'
FOREACH (person IN [p] |
SET person.age = CASE WHEN person.age < 25 THEN person.age + 2 ELSE person.age END);
这个查询会找到名为 "Charlie" 的节点,如果年龄小于 25,则增加 2 岁。
FOREACH
语句用于在一个节点或关系的集合上执行一组操作。它允许在查询中进行迭代和批处理操作,从而对多个元素进行动态的创建、更新或删除。