【问题标题】:How to access the internal id of neo4j node?如何访问neo4j节点的内部id?
【发布时间】:2015-01-15 16:59:40
【问题描述】:

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

我试过这个:

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

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

【问题讨论】:

    标签: neo4j


    【解决方案1】:

    想象一下:

    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,您无法控制自己,它完全由数据库处理(甚至可以重用,因此您不能真正依赖这些值)。每个节点都有只有一个内部 id,并且它在整个数据库中是唯一的,因此您永远无法找到具有相同内部 id 的多个节点。

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

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

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

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

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

    最后一点,如果您想获得图中的所有节点,您可以使用以下查询:

    MATCH (n) RETURN n;
    

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

    【讨论】:

    • 非常感谢。很有用!
    • @dkar,没问题 - 很高兴能帮上忙!
    【解决方案2】:

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

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

    【讨论】:

    • 好的。但我想要做的是:RETURN DISTINCT (n.internalID)。我需要将其用于我的数据,因为它们没有任何其他不同的属性。
    • 我不明白。内部 ID 由 DB 分配,从节点获取它的唯一方法是通过 ID() 函数。当然,您始终可以将自己的 id 属性添加到节点,但这与“内部 ID”不同——您无法显式设置内部 ID。如果这不能说明问题,请提供有关您的情况的更多信息。
    • 也许混淆是OP需要了解数据库中的内部ID不是节点属性。所以你不能说n.internalID 或类似的东西。相反,要获得它,您可以使用 ID() 函数。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2023-03-25
    • 1970-01-01
    • 1970-01-01
    • 2013-06-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多