WITH
语句在 Cypher 查询中用于将之前的查询结果传递给后续的查询操作。它可以用来控制查询的流程,并且常常与其他语句如 MATCH
、RETURN
、CREATE
、DELETE
等一起使用。以下是一些常用的示例和解释:
基本用法:
MATCH (p:Person)
WITH p
RETURN p.name
这个示例首先匹配所有人节点,然后通过 WITH
语句将匹配的结果传递给后续的操作,这里是返回每个人节点的姓名属性。
结合聚合:
MATCH (p:Person)-[:ACTED_IN]->(m:Movie)
WITH p, COUNT(m) AS movie_count
RETURN p.name, movie_count
这个示例匹配参演电影的人节点,然后使用 WITH
语句将每个人节点和他们参演的电影数量传递给后续的操作,最终返回人节点的姓名和电影数量。
多个 WITH
子句:
MATCH (p:Person)-[:ACTED_IN]->(m:Movie)
WITH p, COUNT(m) AS movie_count
WHERE movie_count > 3
WITH p
RETURN p.name
这个示例结合了多个 WITH
子句。首先,它匹配参演电影的人节点,并传递人节点和电影数量给第一个 WITH
子句。然后,第一个 WITH
子句将满足条件的人节点传递给第二个 WITH
子句,然后根据条件过滤,最终返回满足条件的人节点的姓名。
在创建节点时使用 WITH
:
WITH ['Alice', 'Bob', 'Charlie'] AS names
UNWIND names AS name
CREATE (p:Person {name: name})
这个示例使用 WITH
语句将一个字符串列表传递给后续的操作,然后使用 UNWIND
展开列表,逐个创建具有姓名属性的人节点。文章来源:https://www.toymoban.com/news/detail-664682.html
总之,WITH
语句用于控制查询流程,将之前的查询结果传递给后续的操作。它可以用于数据传递、数据转换、条件筛选等操作,使得查询更加灵活和可组合。文章来源地址https://www.toymoban.com/news/detail-664682.html
到了这里,关于Neo4j之with基础的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!