在java的neo4j嵌入式数据库中,我应该如何检查两个节点是否有关系



在java的neo4j嵌入式数据库中,我应该如何检查两个节点是否有关系?

我想要语法或教程链接,我看过neo4j网站但没有找到。

谢谢。

给定两个节点 "nodeA" 和 "nodeB",

  1. 获取附加到"节点 A"的所有关系,

    rels = nodeA.getRelationships();
    
  2. 遍历关系"rels"的集合,对于每个关系"rel",测试另一个端节点是否为节点B

    rel.getOtherNode(nodeA).equals(nodeB)
    
  3. 如果上述表达式适用于其中一个关系,则节点 A 和节点 B 已连接。

这是"Node"和"Relationshiip"的java API,

http://api.neo4j.org/current/

private boolean sharedRelationshipExists( Node nodeA, long nodeBId)
{
    Iterator<Relationship> iterator = nodeA.getRelationships().iterator();
    while ( iterator.hasNext() )
    {
        if (iterator.next().getOtherNode( nodeA ).getId() == nodeBId) return true;
    }
    return false;
}
// in another part
boolean sharedRelationshipBetweenAB;
if ( nodeA.getDegree() < nodeB.getDegree() )
{
    sharedRelationshipBetweenAB = sharedRelationshipExists( nodeA, nodeB.getId() );
}
else
{
    sharedRelationshipBetweenAB = sharedRelationshipExists( nodeB, nodeA.getId() );
}

布尔sharedRelationshipBetweenAB将保存您的答案

最新更新