UNWIND
语句在 Cypher 查询中用于将列表(数组)中的元素逐个“展开”,从而将每个元素视为单独的行进行处理。它通常与 MATCH
、CREATE
、MERGE
等语句结合使用,用于对列表中的每个元素执行相应的操作。以下是一些常用的示例和解释:
基本用法:
UNWIND [1, 2, 3, 4, 5] AS number
RETURN number * 2 AS doubled
这个示例使用 UNWIND
逐个展开给定的列表,然后将每个元素乘以2并返回。
与MATCH结合:
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
逐个展开朋友列表,并返回每个人节点和他们的朋友姓名。
创建节点和关系:
UNWIND ['Alice', 'Bob', 'Charlie'] AS name
CREATE (:Person {name: name})
这个示例使用 UNWIND
逐个展开给定的姓名列表,然后逐个创建具有姓名属性的人节点。
与MERGE结合:
UNWIND ['Alice', 'Bob', 'Charlie'] AS name
MERGE (p:Person {name: name})
ON CREATE SET p.created = timestamp()
RETURN p.name, p.created
这个示例使用 UNWIND
逐个展开给定的姓名列表,然后使用 MERGE
创建具有姓名属性的人节点,如果节点不存在则创建,并在创建时设置一个时间戳属性。文章来源:https://www.toymoban.com/news/detail-661224.html
总之,UNWIND
语句用于逐个展开列表中的元素,将每个元素作为单独的行进行处理。它常用于与其他语句结合,实现对每个元素的操作,从而进行数据转换、节点创建、关系建立等操作。文章来源地址https://www.toymoban.com/news/detail-661224.html
到了这里,关于Neo4j之unwind基础的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!