在 Neo4j 中获取每种类型的节点属性和每种类型的关系属性
Get node properties per type and relation properties per type in Neo4j
我正在使用 Neo4j 附带的 Movie 示例图,我想获得:
- 所有标签
- 所有关系名称
- 每个标签的所有属性
- 每个关系类型的所有属性
我能够得到 1 所有标签 使用:
ResourceIterable<Label> allLabels = GlobalGraphOperations.at(graph).getAllLabels();
所以,我得到:
Movie
Person
我也能够得到 2 所有关系类型 使用:
Iterable<RelationshipType> allRelationshipTypes = GlobalGraphOperations.at(graph).getAllRelationshipTypes();
这是:
ACTED_IN
DIRECTED
PRODUCED
WROTE
FOLLOWS
REVIEWED
最后,我可以获得所有属性,但不是每个标签或每个关系类型,使用:
ResourceIterable<String> allPropertyKeys = GlobalGraphOperations.at(graph).getAllPropertyKeys();
title
released
tagline
name
born
roles
summary
rating
我想得到的是:
Movie: [title, released, tagline]
Person: [name, born]
ACTED_IN: [roles]
DIRECTED: []
PRODUCED: []
WROTE: []
FOLLOWS: []
REVIEWED: [summary, rating]
是否可以使用 Java API 甚至执行 Cypher 查询?
请记住,这是在具有数百万个节点的图形中完成的事情。
在 Neo4j 中查找所有标签很容易。您已经解决了它,它是 Cypher 中的一个简单查询:
match (n) return distinct labels(n)
通过以下查询使用 Cypher 也可以轻松找到所有关系类型:
match (n)-[r]-() return distinct type(r)
但是,对于问题 3 和 4,它变得更加困难。实际上,没有经济有效的方法来获取标签的所有属性或关系类型的所有属性。
关于获取标签的所有属性。这意味着属性 属于标签 就像模式一样(例如,如果您将 DDL 与 RDBMS 进行比较)。目前 Neo4j 中没有内置这种类型的模式支持(当前版本的 Neo4j 在撰写本文时是 2.1.6),因为 Neo4j 基本上是无模式的。这种类型的结构完整性是 quite often handled in the application layer for NoSQL databases。
描述了目前可用于 Neo4j 的唯一模式操作 here。
目前包括:
- 独一无二 - 例如
CREATE CONSTRAINT ON (p:Person) ASSERT p.name IS UNIQUE
- 索引 - 在标签上创建索引,例如
CREATE INDEX ON :Person(name)
如果您想要更多的结构性执行,以下内容可能会有所帮助:
- Structr, a layer above Neo4j that among other things enforces a stricter schema (check the schema docs here)
- SylvaDB,Neo4j 之上的一个易于使用的层,也具有模式支持。看起来很
除此之外,还有工具 NeoProfiler 包含许多分析器,其中大部分 运行 非常简单的 Cypher 查询您的数据库并提供汇总统计信息。一些剖析器实际上会在您的图表中发现数据,然后生成其他剖析器,这些剖析器稍后将 运行。例如,如果在数据中发现名为 "Person" 的标签,则会将标签分析器添加到 运行 队列以检查具有该标签的节点数量。
为了找到 "belongs to a Label" 的所有属性,您必须遍历该类型的所有节点并提取 属性 名称(这可能非常昂贵)。
关系类型也是如此。由于它们不属于任何模式,因此查找为特定类型定义的所有属性是一项昂贵的操作(您将必须遍历所有关系)。
我正在使用 Neo4j 附带的 Movie 示例图,我想获得:
- 所有标签
- 所有关系名称
- 每个标签的所有属性
- 每个关系类型的所有属性
我能够得到 1 所有标签 使用:
ResourceIterable<Label> allLabels = GlobalGraphOperations.at(graph).getAllLabels();
所以,我得到:
Movie
Person
我也能够得到 2 所有关系类型 使用:
Iterable<RelationshipType> allRelationshipTypes = GlobalGraphOperations.at(graph).getAllRelationshipTypes();
这是:
ACTED_IN
DIRECTED
PRODUCED
WROTE
FOLLOWS
REVIEWED
最后,我可以获得所有属性,但不是每个标签或每个关系类型,使用:
ResourceIterable<String> allPropertyKeys = GlobalGraphOperations.at(graph).getAllPropertyKeys();
title
released
tagline
name
born
roles
summary
rating
我想得到的是:
Movie: [title, released, tagline]
Person: [name, born]
ACTED_IN: [roles]
DIRECTED: []
PRODUCED: []
WROTE: []
FOLLOWS: []
REVIEWED: [summary, rating]
是否可以使用 Java API 甚至执行 Cypher 查询? 请记住,这是在具有数百万个节点的图形中完成的事情。
在 Neo4j 中查找所有标签很容易。您已经解决了它,它是 Cypher 中的一个简单查询:
match (n) return distinct labels(n)
通过以下查询使用 Cypher 也可以轻松找到所有关系类型:
match (n)-[r]-() return distinct type(r)
但是,对于问题 3 和 4,它变得更加困难。实际上,没有经济有效的方法来获取标签的所有属性或关系类型的所有属性。
关于获取标签的所有属性。这意味着属性 属于标签 就像模式一样(例如,如果您将 DDL 与 RDBMS 进行比较)。目前 Neo4j 中没有内置这种类型的模式支持(当前版本的 Neo4j 在撰写本文时是 2.1.6),因为 Neo4j 基本上是无模式的。这种类型的结构完整性是 quite often handled in the application layer for NoSQL databases。
描述了目前可用于 Neo4j 的唯一模式操作 here。
目前包括:
- 独一无二 - 例如
CREATE CONSTRAINT ON (p:Person) ASSERT p.name IS UNIQUE
- 索引 - 在标签上创建索引,例如
CREATE INDEX ON :Person(name)
如果您想要更多的结构性执行,以下内容可能会有所帮助:
- Structr, a layer above Neo4j that among other things enforces a stricter schema (check the schema docs here)
- SylvaDB,Neo4j 之上的一个易于使用的层,也具有模式支持。看起来很
除此之外,还有工具 NeoProfiler 包含许多分析器,其中大部分 运行 非常简单的 Cypher 查询您的数据库并提供汇总统计信息。一些剖析器实际上会在您的图表中发现数据,然后生成其他剖析器,这些剖析器稍后将 运行。例如,如果在数据中发现名为 "Person" 的标签,则会将标签分析器添加到 运行 队列以检查具有该标签的节点数量。
为了找到 "belongs to a Label" 的所有属性,您必须遍历该类型的所有节点并提取 属性 名称(这可能非常昂贵)。
关系类型也是如此。由于它们不属于任何模式,因此查找为特定类型定义的所有属性是一项昂贵的操作(您将必须遍历所有关系)。