更新节点但返回更新前的状态
某些用例需要更新节点(或关系)属性,但返回更新前的节点(或关系)。
您需要在更新之前获取节点的“快照”,并返回该快照而不是节点本身。
Neo4j 3.1 及以上版本
您可以使用映射投影来获取节点快照
MATCH (p:Person{name:'Keanu Reeves'})
WITH p, p {.*} as snapshot
SET p.name = 'The One'
RETURN snapshot
返回的映射结果的 name 属性仍将设置为“Keanu Reeves”。
请注意,结果是映射,而不是节点,因此节点 ID 和标签不包含在返回的数据中。
Neo4j 3.0 及以下版本
映射投影不可用,因此请改用 properties()。
MATCH (p:Person{name:'Keanu Reeves'})
WITH p, properties(p) as snapshot
SET p.name = 'The One'
RETURN snapshot
返回的映射结果的 name 属性仍将设置为“Keanu Reeves”。
请注意,结果是映射,而不是节点,因此节点 ID 和标签不包含在返回的数据中。
返回显式空值
如果您需要在 Neo4j 3.0 中将缺失字段(在快照中)显式显示为空值,则需要使用APOC 过程的映射辅助函数。
MATCH (p:Person{name:'Keanu Reeves'})
WITH p, properties(p) as props
CALL apoc.map.setKey(props, 'lastUpdated', null) YIELD value as snapshot
SET p.lastUpdated = timestamp()
RETURN snapshot
如果节点上不存在 lastUpdated 属性,它仍将在映射中返回 null 值,而不是根本不出现。
此页面是否有帮助?