Neo4j之with基础

WITH 语句在 Cypher 查询中用于将之前的查询结果传递给后续的查询操作。它可以用来控制查询的流程,并且常常与其他语句如 MATCHRETURNCREATEDELETE 等一起使用。以下是一些常用的示例和解释:

基本用法

sql 复制代码
MATCH (p:Person)
WITH p
RETURN p.name

这个示例首先匹配所有人节点,然后通过 WITH 语句将匹配的结果传递给后续的操作,这里是返回每个人节点的姓名属性。

结合聚合

sql 复制代码
MATCH (p:Person)-[:ACTED_IN]->(m:Movie)
WITH p, COUNT(m) AS movie_count
RETURN p.name, movie_count

这个示例匹配参演电影的人节点,然后使用 WITH 语句将每个人节点和他们参演的电影数量传递给后续的操作,最终返回人节点的姓名和电影数量。

多个 WITH 子句

sql 复制代码
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

sql 复制代码
WITH ['Alice', 'Bob', 'Charlie'] AS names
UNWIND names AS name
CREATE (p:Person {name: name})

这个示例使用 WITH 语句将一个字符串列表传递给后续的操作,然后使用 UNWIND 展开列表,逐个创建具有姓名属性的人节点。

总之,WITH 语句用于控制查询流程,将之前的查询结果传递给后续的操作。它可以用于数据传递、数据转换、条件筛选等操作,使得查询更加灵活和可组合。

相关推荐
叶楊1 天前
数据处理常用函数
neo4j
向阳蒲公英3 天前
http://localhost:7474/browser/ 登陆之后账号密码neo4j / neo4j 不对 页面出现以下:
neo4j
BTU_YC4 天前
Neo4j查询计划完全指南:读懂数据库的“执行蓝图“
数据库·neo4j
非极限码农4 天前
Neo4j图数据库上手指南
大数据·数据库·数据分析·neo4j
lwprain4 天前
图数据库neo4j desktop2.0初探
数据库·neo4j
老朋友此林5 天前
记录最新 Neo4j 安装过程(截图实操)、使用、踩坑 Neo4j 5.26.13、JDK 17安装
neo4j
小码农叔叔5 天前
【云原生】Neo4j 图数据库从搭建到项目使用深度详解
neo4j·neo4j图数据库·neo4j使用详解·neo4j图数据库详解·neo4j图数据库实战详解·neo4j使用总结
皇族崛起6 天前
金融 - 搭建 图谱挖掘工作流 调研
金融·llm·知识图谱·neo4j·多智能体·findpaper
皇族崛起8 天前
金融 - neo4j、Graph Data Science 安装
金融·知识图谱·neo4j·信息差·ai赋能
羊羊小栈9 天前
基于知识图谱(Neo4j)和大语言模型(LLM)的图检索增强(GraphRAG)的智能音乐推荐系统(vue+flask+AI算法)
人工智能·毕业设计·neo4j·大作业