Neo4j之unwind基础

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

基本用法

sql 复制代码
UNWIND [1, 2, 3, 4, 5] AS number
RETURN number * 2 AS doubled

这个示例使用 UNWIND 逐个展开给定的列表,然后将每个元素乘以2并返回。

与MATCH结合

sql 复制代码
MATCH (p:Person)-[:FRIEND]->(f:Person)
WITH p, COLLECT(f.name) AS friends
UNWIND friends AS friend_name
RETURN p.name, friend_name

这个示例首先匹配拥有朋友关系的人节点,然后使用 COLLECT 聚合函数将每个人节点的朋友姓名收集到列表中,最后使用 UNWIND 逐个展开朋友列表,并返回每个人节点和他们的朋友姓名。

创建节点和关系

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

这个示例使用 UNWIND 逐个展开给定的姓名列表,然后逐个创建具有姓名属性的人节点。

与MERGE结合

sql 复制代码
UNWIND ['Alice', 'Bob', 'Charlie'] AS name
MERGE (p:Person {name: name})
ON CREATE SET p.created = timestamp()
RETURN p.name, p.created

这个示例使用 UNWIND 逐个展开给定的姓名列表,然后使用 MERGE 创建具有姓名属性的人节点,如果节点不存在则创建,并在创建时设置一个时间戳属性。

总之,UNWIND 语句用于逐个展开列表中的元素,将每个元素作为单独的行进行处理。它常用于与其他语句结合,实现对每个元素的操作,从而进行数据转换、节点创建、关系建立等操作。

相关推荐
速易达网络4 天前
Flask实现Neo4j知识图谱Web应用
flask·知识图谱·neo4j
KG_LLM图谱增强大模型4 天前
[290页电子书]打造企业级知识图谱的实战手册,Neo4j 首席科学家力作!从图数据库基础到图原生机器学习
人工智能·知识图谱·neo4j
Psycho_MrZhang4 天前
Neo4j Python SDK手册
开发语言·python·neo4j
坠金4 天前
图数据库neo4j自建及使用
数据库·neo4j
阿也在北京4 天前
基于Neo4j和TuGraph的知识图谱与问答系统搭建——胡歌的导演演员人际圈
python·阿里云·知识图谱·neo4j
北冥码鲲4 天前
【保姆级教程】从零入手:Python + Neo4j 构建你的第一个知识图谱
python·知识图谱·neo4j
weixin_462446235 天前
使用 LangChain + Ollama + Neo4j 构建中文知识图谱完整教程(含 Docker 部署)
langchain·知识图谱·neo4j
抠头专注python环境配置5 天前
解决“No module named ‘tensorflow‘”报错:从导入失败到环境配置成功
人工智能·windows·python·tensorflow·neo4j
我叫张土豆7 天前
2026最强实战:用《三国演义》把 KAG(知识增强生成)跑通:LLM抽取知识图谱→Neo4j入库→召回评测→图谱问答闭环(附完整测试代码)
人工智能·知识图谱·neo4j
Roye_ack7 天前
【Mac 实战】简单知识图谱搭建步骤详解(Neo4j + py2neo)
人工智能·知识图谱·neo4j·py2neo