SDN4 - 更新关系实体的子项会导致关系被删除

SDN4 - Updating a relationship entity's child causes the relationship to be deleted

我正在编写一些 GraphUnit 支持的集成测试,并且在尝试更新现有关系指向的子节点时注意到奇怪的行为。

给定与支持图的现有关系如下:

(A:ParentNode)-[:SOME_REL {id: 1}]->(B:ChildNode)

如果我尝试通过编写如下代码来更新它:

ChildNode newChildNode = new ChildNode();
existingRelationship.setChild(newChild);
RelationshipRepository.save(existingRelationship);

生成的图表如下所示:

(A:ParentNode)
(B:ChildNode)
(C:ChildNode)

但我希望它看起来像:

(A:ParentNode)-[:SOME_REL {id: 1}]->(C:ChildNode)

我在执行 GraphRepository 时看到的原始日志输出 save() 在 Cypher 查询中包含删除关系的 DELETE 语句:

10:32:32.218 [main] DEBUG o.n.o.s.r.SessionRequestHandler - {"statements":[{"statement":"MATCH ()-[_0]->() WHERE id(_0)=0 SET _0+={_0_props}  WITH _0 MATCH ([=14=])-[_1:`SOME_REL`]->() WHERE id([=14=])=0 AND id()=1 AND id(_1)=0 DELETE _1","parameters":{"_0_props":{"doubleProp":1.0}},"resultDataContents":["row"],"includeStats":false}]}
10:32:32.219 [main] INFO  o.n.o.session.request.DefaultRequest - POST http://localhost:7475/db/data/transaction/commit, request: {"statements":[{"statement":"MATCH ()-[_0]->() WHERE id(_0)=0 SET _0+={_0_props}  WITH _0 MATCH ([=14=])-[_1:`SOME_REL`]->() WHERE id([=14=])=0 AND id()=1 AND id(_1)=0 DELETE _1","parameters":{"_0_props":{"doubleProp":1.0}},"resultDataContents":["row"],"includeStats":false}]}

这是一个错误吗?或者我没有正确更新 SDN4 关系实体?每次我们有效地想要进行更新时,我们是否必须删除关系并从头开始创建它们?

不幸的是,这是一个错误。解决方法是使用新的结束节点创建一个新的 SimpleRelationship,替换父 SimpleNode 上的现有关系并保存新的 RE。

可以在此处跟踪问题https://jira.spring.io/browse/DATAGRAPH-706