在 Neo4j 中获取每种类型的节点属性和每种类型的关系属性

Get node properties per type and relation properties per type in Neo4j

我正在使用 Neo4j 附带的 Movie 示例图,我想获得:

  1. 所有标签
  2. 所有关系名称
  3. 每个标签的所有属性
  4. 每个关系类型的所有属性

我能够得到 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" 的所有属性,您必须遍历该类型的所有节点并提取 属性 名称(这可能非常昂贵)。

关系类型也是如此。由于它们不属于任何模式,因此查找为特定类型定义的所有属性是一项昂贵的操作(您将必须遍历所有关系)。