在java的neo4j嵌入式数据库中,我应该如何检查两个节点是否有关系?
我想要语法或教程链接,我看过neo4j网站但没有找到。
谢谢。
给定两个节点 "nodeA" 和 "nodeB",
-
获取附加到"节点 A"的所有关系,
rels = nodeA.getRelationships();
-
遍历关系"rels"的集合,对于每个关系"rel",测试另一个端节点是否为节点B
rel.getOtherNode(nodeA).equals(nodeB)
-
如果上述表达式适用于其中一个关系,则节点 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
将保存您的答案