微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

删除之前的节点和关系,并将其指向具有相同关系的当前节点

如何解决删除之前的节点和关系,并将其指向具有相同关系的当前节点

我正在尝试与父母和孩子建立一种黑白关系。

MERGE (c:Child{name:'CA'})
MERGE (p:Parent{name:'Parent'})

为了建立关系,

MERGE (p)-[:parent_of]->(c)

查询是用名为 createParentChildRelationship 的单独 java 函数编写的。 每当我尝试使用相同的父名称和不同的子名称将参数传递给该函数时,它都会形成一个新的关系。但是我只需要当前的子节点来指向父节点,通过删除以前的子节点及其与父节点的关系。 所以我尝试了这种接近它的方式,

MERGE (c:Child{name:'CA'})
MERGE (p:Parent{name:'Parent'})
MATCH (c)-[r:parent_of]-(p) DELETE r,c,p
CREATE (p)-[:parent_of]->(c) 

但它显示1 property is set 但未创建关系

解决方法

您的查询存在两个问题:

  1. 您正在删除父级、子级和关系。如果您刚刚删除了父级,则无法创建与新子级的新关系。此外,您要删除刚刚创建的子项,而不是父项的当前子项,因此也需要修复。

  2. 如果 MATCH 失败,则没有要执行的行,查询中也不会发生任何其他事情。您可能需要 OPTIONAL MATCH,或者可能需要模式理解。

你可以试试这个:

MERGE (p:Parent {name:'Parent'})
WITH p,[(p)-[:parent_of]->(existing) | existing] as existingChildren
FOREACH (child IN existingChildren | DETACH DELETE child)
MERGE (c:Child {name:'CA'})
CREATE (p)-[:parent_of]->(c)
,

试试这个,它可以在我的 neo4j 桌面上运行;

  1. 找到 CA 和父级之间的关系(可选,因为如果找不到匹配项,它将继续查询)
  2. 删除关系
  3. 找到该父级并在未找到时创建(MERGE)
  4. 使用子节点和父节点,创建新关系
OPTIONAL MATCH (c:Child)-[r:parent_of]-(:Parent{name:'Parent'})
DELETE r
MERGE (p2:Parent{name:'Parent'})
MERGE (p2)-[r2:parent_of]->(c2:Child{name:'CA'})
RETURN c2,r2,p2

您不能删除 c 和 p,因为它在创建过程中仍然是查询的一部分。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。