Neo4j之FOREACH基础

这篇具有很好参考价值的文章主要介绍了Neo4j之FOREACH基础。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在 Neo4j 中,FOREACH 语句用于在查询中对一组元素执行某些操作,通常是在创建或更新节点关系时。它常常与 CREATESET 等操作结合使用。

创建多个关系:

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" 关系的情况下创建关系。

批量更新节点属性:

MATCH (p:Person)
WHERE p.age < 30
FOREACH (person IN [p] | SET person.isYoung = true);

这个查询会找到年龄小于 30 的所有节点,并为每个节点设置 "isYoung" 属性为 true。

根据列表创建关系:

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" 关系,每个关系都有一个不同的评分属性。以下是查询的解释:

  1. MATCH (p:Person), (m:Movie):这一部分使用 MATCH 语句找到满足条件的 "Person" 节点和 "Movie" 节点。其中,(p:Person) 表示一个 "Person" 节点,(m:Movie) 表示一个 "Movie" 节点。

  2. WHERE p.name = 'Bob' AND m.title = 'The Matrix':这一部分使用 WHERE 语句过滤出 "Person" 节点的名字为 "Bob",且 "Movie" 节点的标题为 "The Matrix"。

  3. 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。

条件更新属性:

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 语句用于在一个节点或关系的集合上执行一组操作。它允许在查询中进行迭代和批处理操作,从而对多个元素进行动态的创建、更新或删除。文章来源地址https://www.toymoban.com/news/detail-647512.html

到了这里,关于Neo4j之FOREACH基础的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【neo4j】neo4j的安装与使用

    https://www.oracle.com/java/technologies/downloads/ 按照步骤安装即可 配置环境变量 在系统变量中添加 path变量中添加 https://neo4j.com/deployment-center/ 下载后,在指定位置解压缩 与java相同,也需要设置环境变量。 终端输入neo4j.bat console 成功

    2024年02月03日
    浏览(59)
  • Neo4j之SET基础

    在 Neo4j 中, SET 语句用于更新节点或关系的属性。它允许你修改节点或关系的属性值,可以单独使用,也可以与其他查询语句(如 MATCH 、 CREATE 、 MERGE 等)一起使用。以下是一些使用 SET 语句的常见例子,以及它们的解释: 1】更新单个节点的属性: 这个查询会找到一个具有

    2024年02月13日
    浏览(31)
  • Neo4j之REMOVE基础

    在 Neo4j 中, REMOVE 语句用于从节点中删除特定的属性。这在你需要更新或者清除节点属性时非常有用。 1】删除单个属性: 这个查询会找到具有 \\\"Person\\\" 标签且属性 \\\"name\\\" 为 \\\"Alice\\\" 的节点,并从这些节点中删除 \\\"age\\\" 属性。 2】删除多个属性: 这个查询会找到具有 \\\"Person\\\" 标签且

    2024年02月13日
    浏览(40)
  • Neo4j之MERGE基础

    在 Neo4j 中, MERGE 语句用于根据指定的模式进行创建或匹配节点和关系。它可以在节点或关系不存在时创建它们,并在已存在时进行匹配。 创建或匹配节点: 这个查询会检查是否已经存在一个具有 \\\"Person\\\" 标签且属性 \\\"name\\\" 为 \\\"John\\\" 的节点。如果不存在,则创建一个新节点。

    2024年02月13日
    浏览(44)
  • Neo4j之CALL基础

    CALL 语句用于调用 Neo4j 数据库中预定义的函数、过程或者自定义的函数。它是用来执行一些特定操作或计算的重要工具。以下是一些常用的 CALL 语句示例和解释: 调用内置函数 : 这个示例中,调用了内置函数 db.labels() 来获取数据库中所有的节点标签。 调用自定义函数 :

    2024年02月11日
    浏览(43)
  • Neo4j之with基础

    WITH 语句在 Cypher 查询中 用于将之前的查询结果传递给后续的查询操作 。它可以用来控制查询的流程,并且常常与其他语句如 MATCH 、 RETURN 、 CREATE 、 DELETE 等一起使用。以下是一些常用的示例和解释: 基本用法 : 这个示例首先匹配所有人节点,然后通过 WITH 语句将匹配的结

    2024年02月12日
    浏览(44)
  • Neo4j之union基础

    UNION 用于将多个 MATCH 或 RETURN 子句的结果合并为一个结果集。它可以用来合并不同模式的节点和关系,或者将多个查询的结果合并在一起 。以下是一些常用的示例和解释: 基本用法 : 这个示例中,首先从满足条件的人节点中返回姓名,然后使用 UNION 将结果与满足条件的电

    2024年02月12日
    浏览(44)
  • Neo4j之MATCH基础

    1】基本匹配和返回 :查找所有节点和关系,返回节点的标签和属性。 2】条件筛选 :查找所有名为 \\\"Alice\\\" 的人物节点。 3】关系查询 :查找所有和 \\\"Alice\\\" 有关系的电影节点。 4】多条件筛选 :查找 1990 年之后发行的电影。 5】返回特定属性 :查找 \\\"Alice\\\" 所参演的电影名称。

    2024年02月13日
    浏览(36)
  • Neo4j之unwind基础

    UNWIND 语句在 Cypher 查询中用于将列表(数组)中的元素逐个“展开” ,从而将每个元素视为单独的行进行处理。它通常与 MATCH 、 CREATE 、 MERGE 等语句结合使用,用于对列表中的每个元素执行相应的操作。以下是一些常用的示例和解释: 基本用法 : 这个示例使用 UNWIND 逐个展

    2024年02月12日
    浏览(32)
  • Neo4j之DELETE基础

    在 Neo4j 中, DELETE 语句用于删除节点、关系或节点属性。它允许从图数据库中移除不再需要的数据。 1】删除节点及其关系: 这个查询会找到具有 \\\"Person\\\" 标签且属性 \\\"name\\\" 为 \\\"Alice\\\" 的节点,然后删除该节点以及与之关联的所有关系。 2】删除特定类型的关系: 这个查询会找到

    2024年02月13日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包