Spring Data Neo4j 4.0:创建了重复的节点,应该创建关系

Spring Data Neo4j 4.0: Duplicate nodes created, should create relationship instead

总结: 使用 SDN4,我保留了 10 个对象,其中一半具有相同的内容,只是它们链接到的 ID 不同。链接 ID 设置为 @Transient。不过,创建的两个对象具有相同的内容,而不是一个具有两个指向它的链接的对象。我怎样才能避免这种行为?

详情: 我们通过 CSV 定义了两个域对象和信息源,它们如下所示:

域对象 A CSV:

key,name
1,test1
3,test3

POJO A:

@Transient
private int key;    
private String name;

@Relationship(type = "HAS_CERTIFICATION", direction = "OUTGOING")
private Set<B> bObject = new HashSet<>();

public void setName(String name) {
    this.name = name;
}

@Relationship(type = "HAS_CERTIFICATION", direction = "OUTGOING")
public void hasCertification(B b) {
    bObject.add(b);
    b.getA().add(this);
}

域对象 B:

foreignKey,name,value
1,ISO9001,TRUE
1,ISO14001,TRUE
3,ISO9001,TRUE
3,ISO14001,TRUE

POJO B:

@Transient
private int foreignKey;
private String name;
private String value;

@Relationship(type = "HAS_CERTIFICATION", direction = "INCOMING")
private Set<A> a = new HashSet<>();

public void setName(String name) {
    this.name = name;
}

public void setValue(String value) {
    this.value = value;
}

@Relationship(type = "HAS_CERTIFICATION", direction = "INCOMING")
public Set<A> getA() {
    return a;
}

这些 CSV 文件在各自的 POJO(A 和 B)中被解析并加载到 SDN4 中。

现在我们遍历这些对象并添加关系:

private void aHasCertification(
        Optional<List<B>> b,
        Optional<List<A>> a) {
    for (A aObj : a()) {
        for (B bObj : b()) {
            if(bObj.getForeignKey() == aObj.getKey()) {
                aObj.hasCertification(bObj);
            }
        }
    }
}

然后根存储库repositoryA用于保存加载的对象。 repositoryA.save(domainObjectA);

现在查询数据库时; match n return n;

对于每个 A 对象,将有两个 ISO9001 和两个 ISO14001 对象。而不是我所期望的,每个链接都有两个链接 A:1A:3.

如果我没理解错的话,而不是

你在期待

?

OGM 无法知道具有相同 "name" 的两个 B 实例是同一个节点。您需要做的是通过 属性 加载 B 节点,如果它存在,则使用它与 A 关联,否则创建它。 我怀疑您需要进一步处理 CSV 数据,而不是使用几乎 1:1 映射到 CSV 行的对象来建模。