Neo4j
Материал из Википедии — свободной encyclopedia
Neo4j — графовая система управления базами данных с открытым исходным кодом, реализованная на Java. По состоянию на 2015 год считается самой распространённой графовой СУБД[4]. Разработчик — американская компания Neo Technology, разработка ведётся с 2003 года[5].
Neo4j | |
---|---|
Тип | Графовая СУБД |
Разработчик | Neo Technology |
Написана на | Java и Scala |
Первый выпуск | февраль 2010[1] |
Аппаратная платформа | Java Virtual Machine |
Последняя версия | |
Тестовая версия | 3.4.0 alpha10 (20 марта 2018; 6 лет назад (2018-03-20)) |
Репозиторий | github.com/neo4j/neo4j |
Лицензия | GNU GPL 3[3] и AGPL v3.0[3] |
Сайт | neo4j.com |
Медиафайлы на Викискладе |
Данные хранит в собственном формате, специализированно приспособленном для представления графовой информации, такой подход в сравнении с моделированием графовой базы данных средствами реляционной СУБД позволяет применять дополнительную оптимизацию в случае данных с более сложной структурой[6]. Также утверждается о наличии специальных оптимизаций для SSD-накопителей, при этом для обработки графа не требуется его помещение целиком в оперативную память вычислительного узла, таким образом, возможна обработка достаточно больших графов.
Основные транзакционные возможности[7] — поддержка ACID и соответствие спецификациям JTA, JTS и XA. Интерфейс программирования приложений для СУБД реализован для многих языков программирования, включая Java, Python, Clojure, Ruby, PHP, также реализовано API в стиле REST. Расширить программный интерфейс можно как с помощью серверных плагинов, так и с помощью неуправляемых расширений (unmanaged extensions); плагины могут добавлять новые ресурсы к REST-интерфейсу для конечных пользователей, а расширения позволяют получить полный контроль над программным интерфейсом, и могут содержать произвольный код, поэтому их следует использовать с осторожностью[8].
В СУБД используется собственный язык запросов — Cypher[англ.], но запросы можно делать и другими способами, например, напрямую через Java API и на языке Gremlin[англ.], созданном в проекте с открытым исходным кодом TinkerPop. Cypher является не только языком запросов, но и языком манипулирования данными, так как предоставляет функции CRUD для графового хранилища[9].