This article has multiple issues. Please help improve it or discuss these issues on the talk page . (Learn how and when to remove these messages)
|
Developer(s) | Neo4j Inc. |
---|---|
Initial release | 2007[1] |
Stable release | |
Repository | |
Written in | Java |
Type | Graph database |
License |
|
Website | neo4j |
Neo4j is a graph database management system (GDBMS) developed by Neo4j Inc.
The data elements Neo4j stores are nodes, edges connecting them, and attributes of nodes and edges. Described by its developers as an ACID-compliant transactional database with native graph storage and processing, [3] Neo4j is available in a non-open-source "community edition" licensed with a modification of the GNU General Public License, with online backup and high availability extensions licensed under a closed-source commercial license. [4] Neo also licenses Neo4j with these extensions under closed-source commercial terms. [5]
Neo4j is implemented in Java and accessible from software written in other languages using the Cypher query language through a transactional HTTP endpoint, or through the binary "Bolt" protocol. [6] [7] [8] [9] The "4j" in Neo4j is a reference to its being built in Java, however is now largely viewed as an anachronism. [10]
Neo4j is developed by Neo4j, Inc., based in San Mateo, California, United States and Malmö, Sweden.
Version 1.0 was released in February 2010. [11]
Neo4j version 2.0 was released in December 2013. [12]
Neo4j version 3.0 was released in April 2016. [13]
In November 2016, Neo4j successfully secured $36M in Series D Funding led by Greenbridge Partners Ltd. [14]
In November 2018, Neo4j successfully secured $80M in Series E Funding led by One Peak Partners and Morgan Stanley Expansion Capital, with participation from other investors including Creandum, Eight Roads and Greenbridge Partners. [15]
In June 2021, Neo4j announced another round of funding, $325M in Series F. [16]
Release | First release [17] | Latest minor version [18] | Latest release [18] | End of Support Date [17] |
---|---|---|---|---|
1.0 | 2010-02-23 | 1.0 | — | 2011-08-23 |
1.1 | 2010-07-30 | 1.1 | — | 2012-01-30 |
1.2 | 2010-12-29 | 1.2 | — | 2012-06-29 |
1.3 | 2011-04-12 | 1.3 | — | 2012-09-12 |
1.4 | 2011-07-08 | 1.4 | — | 2013-01-08 |
1.5 | 2011-11-09 | 1.5 | — | 2013-03-09 |
1.6 | 2012-01-22 | 1.6 | — | 2013-07-22 |
1.7 | 2012-04-18 | 1.7 | — | 2013-10-18 |
1.8 | 2012-09-28 | 1.8 | — | 2014-03-28 |
1.9 | 2013-05-21 | 1.9.9 | 2014-10-13 | 2014-11-21 |
2.0 | 2013-12-11 | 2.0.4 | 2014-07-08 | 2015-06-11 |
2.1 | 2014-05-29 | 2.1.8 | 2015-04-01 | 2015-11-29 |
2.2 | 2015-03-25 | 2.2.10 | 2016-06-16 | 2016-09-25 |
2.3 | 2015-10-21 | 2.3.12 | 2017-12-12 | 2017-04-21 |
3.0 | 2016-04-16 | 3.0.12 | 2017-10-03 | 2017-10-31 |
3.1 | 2016-12-13 | 3.1.9 | 2018-06-05 | 2018-06-13 |
3.2 | 2017-05-11 | 3.2.14 | 2019-02-26 | 2018-11-31 |
3.3 | 2017-10-24 | 3.3.9 | 2018-11-02 | 2019-04-28 |
3.4 | 2018-05-17 | 3.4.17 | 2019-11-19 | 2020-03-31 |
3.5 | 2018-11-29 | 3.5.35 | 2022-08-11 | 2022-05-27 |
4.0 | 2020-01-15 | 4.0.12 | 2021-07-06 | 2021-07-14 |
4.1 | 2020-06-23 | 4.1.12 | 2022-08-11 | 2021-12-22 |
4.2 | 2020-11-17 | 4.2.19 | 2022-08-11 | 2022-05-16 |
4.3 | 2021-06-17 | 4.3.23 | 2022-12-21 | 2022-12-16 |
4.4 | 2021-12-02 | 4.4.39 | 2024-11-25 | 2025-06-30 |
5.0 | 2022-10-06 | 5.0 | — | 2022-10-24 |
5.1 | 2022-10-24 | 5.1 | — | Release of 5.2 |
5.2 | 2022-11-21 | 5.2 | — | Release of 5.3 |
5.3 | 2022-12-15 | 5.3 | — | Release of 5.4 |
5.4 | 2023-01-26 | 5.4 | — | Release of 5.5 |
5.5 | 2023-02-16 | 5.5 | — | Release of 5.6 |
5.6 | 2023-03-24 | 5.6 | — | Release of 5.7 |
5.7 | 2023-04-20 | 5.7 | — | Release of 5.8 |
5.8 | 2023-05-16 | 5.8 | — | Release of 5.9 |
5.9 | 2023-06-15 | 5.9 | — | Release of 5.10 |
5.10 | 2023-07-19 | 5.10 | — | Release of 5.11 |
5.11 | 2023-08-15 | 5.11 | — | Release of 5.12 |
5.12 | 2023-09-14 | 5.12 | — | Release of 5.13 |
5.13 | 2023-10-23 | 5.13 | — | Release of 5.14 |
5.14 | 2023-11-24 | 5.14 | — | Release of 5.15 |
5.15 | 2023-12-15 | 5.15 | — | Release of 5.16 |
5.16 | 2024-01-22 | 5.16 | — | Release of 5.17 |
5.17 | 2024-02-23 | 5.17 | — | Release of 5.18 |
5.18 | 2024-03-13 | 5.18.1 | 2024-03-18 | Release of 5.19 |
5.19 | 2024-04-12 | 5.19 | — | Release of 5.20 |
5.20 | 2024-05-23 | 5.20 | — | Release of 5.21 |
5.21 | 2024-06-28 | 5.21.2 | 2024-07-09 | Release of 5.22 |
5.22.0 | 2024-07-25 | 5.22.0 | — | Release of 5.23 |
5.23 | 2024-08-22 | 5.23 | — | Release of 5.24 |
5.24 | 2024-09-27 | 5.24.2 | 2024-10-15 | Release of 5.25 |
5.25.1 | 2024-10-31 | 5.25.1 | — | |
5.26 (LTS) | 2024-12-09 | 5.26 | — |
Neo4j comes in five editions. Two are on-premises editions, Community (free) and Enterprise, and three are cloud-only editions: AuraDB Free, AuraDB Professional, and AuraDB Enterprise.
It is dual-licensed: GPL v3 (with parts of the code under AGPLv3 with Commons Clause), and a proprietary license. The Community Edition is free but is limited to running on one node only due to the lack of clustering and is without hot backups. [19]
The Enterprise Edition unlocks these limitations, allowing for clustering, hot backups, and monitoring. The Enterprise Edition is available under a closed-source commercial license.
The licensing is controversial and has been the subject of at least one lawsuit. [20]
The data elements are nodes, edges which connect nodes to one another, and attributes of nodes and edges. Nodes and edges can be labelled. Labels can be used to narrow searches. As of version 2.0, indexing was added to Cypher with the introduction of schemas. [21] Previously, indexes were supported separately from Cypher. [22]
Database researcher Andy Pavlo from Carnegie Mellon University has questioned graph databases' decision to abandon the longstanding relational model in favor of a custom model. [23] Researchers from CWI benchmarked a modified version of DuckDB against Neo4j on graph-related workloads and found that, despite being an extension of a relational database running SQL, their implementation outperforms Neo4j in a few specific tasks. [24]
Neo4j sued PureThink, a small business that had used a power created under the terms of the GNU AGPL, to remove a restrictive Commons clause that Neo4j had added to the AGPL license. [20] [25] The United States District Court for the Northern District of California made a decision on 2024-07-22 to impose $597,000 in actual damages on PureThink, having previously decided that PureThink had violated the DMCA by removing the Commons Clause from Neo4j's AGPL license, and that it had violated trademark law by continuing to use the name Neo4j in selling to government agencies. [26]
Berkeley DB (BDB) is an embedded database software library for key/value data, historically significant in open-source software. Berkeley DB is written in C with API bindings for many other programming languages. BDB stores arbitrary key/data pairs as byte arrays and supports multiple data items for a single key. Berkeley DB is not a relational database, although it has database features including database transactions, multiversion concurrency control and write-ahead logging. BDB runs on a wide variety of operating systems, including most Unix-like and Windows systems, and real-time operating systems.
Db2 is a family of data management products, including database servers, developed by IBM. It initially supported the relational model, but was extended to support object–relational features and non-relational structures like JSON and XML. The brand name was originally styled as DB2 until 2017, when it changed to its present form.
A query language, also known as data query language or database query language (DQL), is a computer language used to make queries in databases and information systems. In database systems, query languages rely on strict theory to retrieve information. A well known example is the Structured Query Language (SQL).
A spatial database is a general-purpose database that has been enhanced to include spatial data that represents objects defined in a geometric space, along with tools for querying and analyzing such data.
The GNU Affero General Public License is a free, copyleft license published by the Free Software Foundation in November 2007, and based on the GNU GPL version 3 and the Affero General Public License (non-GNU).
A graph database (GDB) is a database that uses graph structures for semantic queries with nodes, edges, and properties to represent and store data. A key concept of the system is the graph. The graph relates the data items in the store to a collection of nodes and edges, the edges representing the relationships between the nodes. The relationships allow data in the store to be linked together directly and, in many cases, retrieved with one operation. Graph databases hold the relationships between data as a priority. Querying relationships is fast because they are perpetually stored in the database. Relationships can be intuitively visualized using graph databases, making them useful for heavily inter-connected data.
FlockDB was an open-source distributed, fault-tolerant graph database for managing wide but shallow network graphs. It was initially used by Twitter to store relationships between users, e.g. followings and favorites. FlockDB differs from other graph databases, e.g. Neo4j in that it was not designed for multi-hop graph traversal but rather for rapid set operations, not unlike the primary use-case for Redis sets. FlockDB was posted on GitHub shortly after Twitter released its Gizzard framework, which it used to query the FlockDB distributed datastore. The database is licensed under the Apache License.
Volt Active Data is an in-memory database designed by Michael Stonebraker, Sam Madden, and Daniel Abadi.
The open-core model is a business model for the monetization of commercially produced open-source software. The open-core model primarily involves offering a "core" or feature-limited version of a software product as free and open-source software, while offering "commercial" versions or add-ons as proprietary software. The term was coined by Andrew Lampitt in 2008.
Sones GraphDB was a graph database developed by the German company sones GmbH, available from 2010 to 2012. Its last version was released in May 2011. sones GmbH, which was based in Erfurt and Leipzig, was declared bankrupt on January 1, 2012.
Opa is a programming language for developing scalable web applications. It is free and open-source software released under a GNU Affero General Public License (AGPLv3), and an MIT License.
A cloud database is a database that typically runs on a cloud computing platform and access to the database is provided as-a-service. There are two common deployment models: users can run databases on the cloud independently, using a virtual machine image, or they can purchase access to a database service, maintained by a cloud database provider. Of the databases available on the cloud, some are SQL-based and some use a NoSQL data model.
Cypher is a declarative graph query language that allows for expressive and efficient data querying in a property graph.
Lightning Memory-Mapped Database (LMDB) is an embedded transactional database in the form of a key-value store. LMDB is written in C with API bindings for several programming languages. LMDB stores arbitrary key/data pairs as byte arrays, has a range-based search capability, supports multiple data items for a single key and has a special mode for appending records (MDB_APPEND) without checking for consistency. LMDB is not a relational database, it is strictly a key-value store like Berkeley DB and DBM.
DBeaver is a SQL client software application and a database administration tool. For relational databases it uses the JDBC application programming interface (API) to interact with databases via a JDBC driver. For other databases (NoSQL) it uses proprietary database drivers. It provides an editor that supports code completion and syntax highlighting. It provides a plug-in architecture that allows users to modify much of the application's behavior to provide database-specific functionality or features that are database-independent. It is written in Java and based on the Eclipse platform.
Realm is an open source object database management system, initially for mobile operating systems (Android/iOS) but also available for platforms such as Xamarin, React Native, and others, including desktop applications (Windows). It is licensed under the Apache License.
Grafana is a multi-platform open source analytics and interactive visualization web application. It can produce charts, graphs, and alerts for the web when connected to supported data sources.
GQL is a standardized query language for property graphs first described in ISO/IEC 76120, released in April 2024 by ISO/IEC.
TerminusDB is an open source knowledge graph and document store. It is used to build versioned data products. It is a native revision control database that is architecturally similar to Git. It is listed on DB-Engines.
RavenDB is an open-source document-oriented database written in C#, developed by Hibernating Rhinos Ltd. It is cross-platform, supported on Windows, Linux, and Mac OS. RavenDB stores data as JSON documents and can be deployed in distributed clusters with master-master replication.
{{cite web}}
: Missing or empty |title=
(help)