仅在一个实体中的 Neo4j OGM 关系

Neo4j OGM relationship in one entity only

我有两个 NodeEntity 类,它们将以多对一关系(如多对一)相关。假设许多实体 A 与单个实体 B 相关。我希望能够加载深度大于 0 的实体 B,但不加载许多相关的实体 A,实际上永远不需要访问实体 A来自实体B.

是否可以仅在实体 A 上指定关系,将其从实体 B 中排除,这样加载实体 B 不会加载任何实体 A,但加载实体 A 会加载实体 B?我担心事后保存实体,因为我不想在保存实体 B 时失去关系。

是的,你可以做到。查看此测试用例

@Test
@Transactional
public void shouldNotDeleteUnmappedRelations() throws Exception {

    session.purgeDatabase();
    session.query("CREATE (a1:A) CREATE (a2:A) CREATE (b:B{name:'b'}) CREATE (a1)-[:REL]->(b) CREATE (a2)-[:REL]->(b) RETURN id(b) as id", Collections.emptyMap());

    Collection<B> res = session.loadAll(B.class, new Filters("name", "b"), 0);
    B b = res.iterator().next();
    assertThat(b).isNotNull();

    session.save(b);
    session.clear();

    Collection<A> allA = session.loadAll(A.class);
    assertThat(allA).hasSize(2);
    assertThat(allA).extracting("b").isNotNull();
}