如何访问neo4j节点的内部id?

时间:2015-01-15 16:59:40

标签: neo4j

我知道我应该避免在neo4j中使用内部id,但有没有办法在neo4j中访问节点的内部id,并根据这个内部id返回DISTINCT所有节点?

我试过这个:

         match (n) where id(n)=123 return n;

这会返回内部id = 123的节点但是如何根据内部id获取数据库中存在的所有节点?

2 个答案:

答案 0 :(得分:4)

想象一下:

CREATE (:SomeLabel {myId:123})-[:someRelationshipType]->(:SomeLabel {myId:456})

这将创建一个两个节点之间的关系。关系的类型为someRelationshipType

那么,如果执行以下查询会发生什么?

MATCH 
    (s:SomeLabel)-[rel:someRelationshipType]->(target:SomeLabel)
RETURN 
    ID(s),       // Built-in Neo4j function to retrieve the internal node id
    s.myId,      // Access the property myId that you created above
    LABELS(s),   // Lists all labels for the start node
    ID(rel),     // Built-in Neo4j function to retrieve the internal relationship id
    TYPE(rel),   // Built-in Neo4j function to retrieve the relationship type
    ID(target),  // Built-in Neo4j function to retrieve the internal node id
    target.myId  // Access the property myId that you created above

查询的输出类似于:

ID(root) | root.myId | LABELS(root) | ID(rel) | TYPE(rel)            | ID(target) | target.myId
-----------------------------------------------------------------------------------------------
192      | 123       | SomeLabel    | 271     | someRelationshipType | 193        | 456

这显示了一些有趣的事情。首先,有一些内置函数可以返回您自己没有提供的值。 ID()函数返回节点或关系的内部ID 。这是一个生成的id,你无法控制自己,它完全由数据库处理(它甚至可以被重用,所以你不能真正依赖这些值)。每个节点都有正好一个内部标识,并且它在整个数据库中是唯一的,因此您永远不会找到具有相同内部标识的多个节点。

但是,在上面的查询中还有一个名为myId的属性。可能有多个节点实际上具有该属性的相同值,因为它是我们自己创建的属性。确保这些属性包含唯一值的唯一方法是使用UNIQUE - 约束(see the docs here)。

可以使用以下语法设置唯一约束:

CREATE CONSTRAINT ON (n:SomeLabel) ASSERT n.myId IS UNIQUE

原始MATCH - 查询中的其他函数是:

  • LABELS - 返回属于节点
  • 的所有labels的列表
  • TYPE - 返回创建节点时指定的关系类型。

最后一点,如果您想要掌握图表中的所有节点,您可以使用以下查询:

MATCH (n) RETURN n;

但是,请注意 - 如果图表很大,检索所有节点很可能是一项痛苦/昂贵的操作。

答案 1 :(得分:1)

一次只能有一个节点具有给定的内部ID。删除节点后,可以将其内部ID重新分配给新节点,但不能在此之前重新分配。

因此,您的查询最多只能返回一个结果。