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

相关推荐
亦暖筑序5 天前
GraphRAG vs 传统向量RAG:Spring AI实战对比
知识图谱·neo4j·向量数据库·rag·spring ai·graphrag
i建模6 天前
Milvus 和neo4j对比
neo4j·milvus
哥本哈士奇(aspnetx)7 天前
看完《低智商犯罪》,学习Cypher构建知识图谱
neo4j
子榆.10 天前
CANN TensorFlow适配器:当tf.matmul跑在昇腾NPU上时在底层发生了什么
人工智能·neo4j·llama
lzp079111 天前
基于多模态视觉模型和图文向量模型的工业图像知识库研究与应用(伍)
数据库·学习·neo4j
子榆.12 天前
CANN ATC编译器:模型从Python到达芬奇指令走了多远
开发语言·python·neo4j
程序员清洒12 天前
一个Token的昇腾之旅——从模型输入到硬件执行的完整链路
neo4j·cann
林夕0715 天前
Qt集成AI推理引擎:TensorFlow Lite与ONNX Runtime实战
人工智能·qt·neo4j
格鸰爱童话17 天前
springboot3.2使用neo4j
springboot·neo4j
Yeats_Liao20 天前
智能感知低功耗设计:MCU上的AI异常检测与能效优化
人工智能·单片机·物联网·neo4j