gpt4 book ai didi

neo4j - 如何访问neo4j节点的内部ID?

转载 作者:行者123 更新时间:2023-12-04 18:41:59 24 4
gpt4 key购买 nike

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

我试过这个:

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

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

最佳答案

想象一下:

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 查询一部分的其他函数是:

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

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

MATCH (n) RETURN n;

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

关于neo4j - 如何访问neo4j节点的内部ID?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27968827/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com