Neo4j - 概述

Neo4j是全球领先的开源图形数据库,采用Java技术开发。 它具有高度可扩展性和无架构 (NoSQL)。

什么是图形数据库?

图表是一组对象的图形表示,其中一些对象对通过链接连接。 它由两个元素组成 - 节点(顶点)和关系(边)。

图形数据库是用于以图的形式对数据进行建模的数据库。 在这里,图的节点描述了实体,而关系描述了这些节点的关联。

流行的图形数据库

Neo4j 是一种流行的图形数据库。 其他图形数据库包括 Oracle NoSQL 数据库、OrientDB、HypherGraphDB、GraphBase、InfiniteGraph 和 AllegroGraph。

为什么选择图形数据库?

如今,大多数数据都以不同对象之间的关系的形式存在,而且更多时候,数据之间的关系比数据本身更有价值。

关系数据库存储高度结构化的数据,这些数据有多个记录存储相同类型的数据,因此它们可用于存储结构化数据,但它们不存储数据之间的关系。

与其他数据库不同,图形数据库将关系和连接存储为一流实体。

与其他数据库相比,图形数据库的数据模型更简单,并且可以与 OLTP 系统一起使用。 它们提供事务完整性和操作可用性等功能。

RDBMS 与图形数据库

下面是关系型数据库和图形数据库的比较表。

Sr.No 关系数据库管理系统 图形数据库
1 表格 图表
2 节点
3 列和数据 属性及其值
4 约束 关系
5 加入 遍历

Neo4j 的优点

以下是Neo4j的优点。

  • 灵活的数据模型 − Neo4j 提供了灵活简单但功能强大的数据模型,可以根据应用程序和行业轻松更改。

  • 实时洞察 − Neo4j 提供基于实时数据的结果。

  • 高可用性 − Neo4j 对于具有事务保证的大型企业实时应用程序具有高度可用性。

  • 连通和半结构数据 − 使用 Neo4j,您可以轻松表示连接的半结构化数据。

  • 轻松检索 − 与其他数据库相比,使用 Neo4j,您不仅可以表示,还可以更快地轻松检索(遍历/导航)连接的数据。

  • Cypher 查询语言 − Neo4j 提供了一种声明性查询语言,使用 ascii-art 语法直观地表示图形。 这种语言的命令是人类可读的格式,非常容易学习。

  • 无连接 − 使用 Neo4j,不需要复杂的联接来检索连接/相关数据,因为无需联接或索引即可轻松检索其相邻节点或关系详细信息。

Neo4j 的功能

以下是 Neo4j 的显着特性 −

  • 数据模型(灵活的模式) − Neo4j 遵循名为本机属性图模型的数据模型。 这里,图包含节点(实体),并且这些节点彼此连接(通过关系来描述)。 节点和关系将数据存储在称为属性的键值对中。

    在 Neo4j 中,无需遵循固定的模式。 您可以根据需要添加或删除属性。 它还提供架构约束。

  • ACID 属性 − Neo4j 支持完整的 ACID(原子性、一致性、隔离性和持久性)规则。

  • 可扩展性和可靠性 − 您可以通过增加读/写次数和卷来扩展数据库,而不会影响查询处理速度和数据完整性。 Neo4j 还提供对复制的支持,以确保数据安全性和可靠性。

  • Cypher 查询语言 − Neo4j 提供了一种强大的声明性查询语言,称为 Cypher。 它使用 ASCII-art 来描绘图形。 Cypher 易于学习,可用于创建和检索数据之间的关系,而无需使用连接等复杂查询。

  • 内置 Web 应用程序 − Neo4j 提供内置的 Neo4j 浏览器 Web 应用程序。 使用它,您可以创建和查询图形数据。

  • 驱动程序 − Neo4j 可以与 −

    • REST API 可与 Java、Spring、Scala 等编程语言配合使用。

    • Java 脚本,可与 Node JS 等 UI MVC 框架配合使用。

    • 它支持两种Java API:Cypher API和Native Java API来开发Java应用程序。 除此之外,您还可以使用其他数据库,例如 MongoDB、Cassandra 等。

  • 索引 − Neo4j 通过使用 Apache Lucence 支持索引。