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

相关推荐
jieshenai19 小时前
使用VSCode远程连接服务器并解决Neo4j无法登陆问题
服务器·vscode·neo4j
dogplays20 小时前
neo4j desktop基本入门
数据库·neo4j
B站计算机毕业设计超人1 天前
计算机毕业设计Python+Neo4j知识图谱医疗问答系统 大模型 机器学习 深度学习 人工智能 大数据毕业设计 Python爬虫 Python毕业设计
爬虫·python·深度学习·机器学习·知识图谱·课程设计·neo4j
AI完全体2 天前
【AI日记】24.11.08 Knowledge Graphs for RAG (知识图谱,Neo4j,Cypher)
人工智能·自然语言处理·知识图谱·neo4j·rag·日记·cypher
颜淡慕潇2 天前
【数据库系列】 Spring Boot 集成 Neo4j 的详细介绍
java·数据库·spring boot·后端·neo4j
sagima_sdu2 天前
Python 操作 Neo4J,Python 库 Py2Neo
python·oracle·neo4j
B站计算机毕业设计超人2 天前
计算机毕业设计Python+Neo4j中华古诗词可视化 古诗词智能问答系统 古诗词数据分析 古诗词情感分析 PyTorch Tensorflow LSTM
pytorch·python·深度学习·机器学习·知识图谱·neo4j·数据可视化
我就是全世界4 天前
如何用Neo4j做知识图谱
人工智能·知识图谱·neo4j
麦麦大数据7 天前
基于vue+neo4j 的中药方剂知识图谱可视化系统
vue.js·知识图谱·neo4j