热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Neo4j数据库简介

作为世界先进的图数据库,Neo4j成为了时下许多互联网公司的首

作为世界先进的图数据库,Neo4j成为了时下许多互联网公司的首

作为世界先进的图数据库,Neo4j成为了时下许多互联网公司的首选。Neo4j是基于java开发的开源图数据库,也是一种NoSQL数据库。Neo4j在保证对数据关系的良好刻画的同时,还支持传统关系型数据的ACID特性,并且在存储效率,集群支持以及失效备援等等方面都有着不错的表现。近来因为实验室的项目的关系,对Neo4j有了一定的了解。同时,我也对其设计思想和架构都产生了很大的兴趣,所以写下这篇博客,帮助大家更好地了解这一数据库,也分享一下以及的认识。

设计理念

Neo4j的设计动机是为了更好地同时也更高效地描述实体之间的关系。在现实生活中,每一个实体都于周围的其他实体有着千丝万缕的关系,这些关系里面所存储的信息甚至要大于身体本身的属性。然后传统的关系型数据库更注重刻画实体内部的属性,实体与实体之间的关系通常都是利用外键来实现。所以在求解关系的时候通常需要join操作,而join操作通常又是耗时的。互联网尤其是移动互联网的爆发式增长本来就使得传统关系型数据库不堪重负,再加上诸如社交网络等应用对于关系的高需求,可以说关系型数据库已经是毫无优势。而图数据库作为重点描述数据之间关系的数据库应运而生,成为了NoSQL中非常重要的一部分。而Neo4j正是图数据库中最为优秀的之一

Neo4j数据库只有两种类型的数据:

  • 节点Node:节点类似于E-R图种的实体(entity),每个实体可以有0到多个属性,这些属性以key-value对的形式存在,并且对属性没有类别要求,也无需提前定义。另外,还允许给每个节点打上标签,以区别不同类型的节点。
  • 关系Relationship: 关系类似于E-R图种的关系(relationship),一个关系有一个起始节点和一个终止节点构成。另外和node一样,关系也可以有多个属性已经标签

    其具体的结构如下图:Neo4j的数据结构而一个实际的图数据库例子就如下图所示的这样:\

    正是基于这样的设计理念,Neo4j有了以下这些特性:<喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHVsPgo8bGk+udjPtdTatLS9qLXEyrG68r7N0tG+rcq1z9bBy6Os0vK2+NTasunRr7nYz7W1xMqxuvLKx9K7uPZPKDEptcSy2df3PGxpPsv509C1xLnYz7XU2k5lbzRq1tC2vMrHzay1yNbY0qq1xDxsaT7M4bmpwcvNvLXEye62yNPFz8jL0cv3oaK547bI08XPyMvRy/ehotfutszCt762oaK88rWlwre+ttLRvq1EaWprc3RyYbXItcjL47eoCjxoMT4KTmVvNGq1xLTmtKK94bm5PC9oMT4KPHA+z9bU2sjDztLDx8C0v7S/tMr9vt3U2k5lbzRq1tDKx8jnus605rSitcSjrMrXz8jKx73ateNOb2RltcQmIzI2Njg0O8q9o7ogTm9kZTppbl91c2UoYnl0ZSkmIzQzO25leHRfcmVsX2lkKGludCkmIzQzO25leHRfcHJvcF9pZChpbnQpLMO/0rvOu7XEvt/M5dLi0uXI58/Co7o8L3A+Cjx1bD4KPGxpPmluX3VzZToxse3KvrjDvdq147G7yrnTw6OsMLHtyr6xu8m+s/08bGk+bmV4dF9yZWxfaWQoaW50KTq4w73atePPwtK7uPa52M+1aWQ8bGk+bmV4dF9wcm9wX2lkKGludCk6uMO92rXjz8LSu7j2yvTQ1LXEaWQKPHA+UmVsYXRpb24mIzI2Njg0O8q9o7ogaW5fdXNlJiM0MztmaXJzdF9ub2RlJiM0MztzZWNvbmRfbm9kZSYjNDM7cmVsX3R5cGUmIzQzO2ZpcnN0X3ByZXZfcmVsX2lkJiM0MztmaXJzdF9uZXh0X3JlbF9pZCYjNDM7c2Vjb25kX3ByZXZfcmVsX2lkJiM0MztzZWNvbmRfbmV4dF9yZWxfaWQmIzQzO25leHRfcHJvcF9pZDwvcD4KPHVsPgo8bGk+aW5fdXNlLG5leHRfcHJvcF9pZDrNrMnPPGxpPmZpcnN0X25vZGU6tbHHsLnYz7W1xMbwyry92rXjPGxpPnNlY29uZF9ub2RlOrWxx7C52M+1tcTW1da5vdq14zxsaT5yZWxfdHlwZTq52M+1wODQzTxsaT5maXJzdF9wcmV2X3JlbF9pZCAmYW1wOyBmaXJzdF9uZXh0X3JlbF9pZDrG8Mq8vdq147XEx7DSu7j2us2689K7uPa52M+1aWQ8bGk+c2Vjb25kX3ByZXZfcmVsX2lkICZhbXA7IHNlY29uZF9uZXh0X3JlbF9pZDrW1da5vdq147XEx7DSu7j2us2689K7uPa52M+1aWQKPHA+z+DQxb+0wcu05sr9veG5udauuvOjrLTzvNLWqrXAzqrKssO0TmVvNGrU2rLp0a+92rXjudjPtbXEyrG68rvhyOe0y9auv+zBy6Os0vLOqsO/0ru49r3atePT0MTE0Km52M+1trzKx9axvdO05tTauMO92rXjtcS2qNLl0/LE2rXEo6zWsb3Tt8POyr7N0NDBy6OsuPmxvrK70OjSqtTZyKWy6dXSwe3N4tK71cWx7aGjPC9wPgo8cD7PwsPmvtnSu7j2zby1xLHpwPq1xMD919OjujwvcD4KPHVsPgo8bGk+tNO92rXjMb+qyryjrL/ttsjTxc/IsenA+qOsxuS05rSiveG5uc6qo7owMSAwMDAwMDAwMiBmZmZmZmZmZjxsaT7G5M/C0ru49rnYz7VpZMrHMqOst8POyrnYz7Uyo7owMSAwMDAwMDAwMSAwMDAwMDAwNCAgMDAwMDAwMDAgICBmZmZmZmZmZiAwMDAwMDAwMSAgIGZmZmZmZmZmIGZmZmZmZmZmICAgIGZmZmZmZmZmILXDs/Zub2RlIDEgLSZndDsgbm9kZSA0LM2syrHPwrj2udjPtcrHMTxsaT652M+1MaO6IDAxIDAwMDAwMDAxIDAwMDAwMDAzICAwMDAwMDAwMCAgIDAwMDAwMDAyIDAwMDAwMDAwICAgMDAwMDAwMDMgZmZmZmZmZmYgICAgZmZmZmZmZmYgbm9kZTEgLSZndDsgbm9kZSAzLG5vZGUzINPQxuTL+7nYz7WjrMv50tS9q25vZGUztObI67bTwdCjrM2syrG3w87KudjPtTA8bGk+udjPtTCjujAxIDAwMDAwMDAxIDAwMDAwMDAyICAwMDAwMDAwMCAgIDAwMDAwMDAxIGZmZmZmZmZmICAgZmZmZmZmZmYgZmZmZmZmZmYgICAgZmZmZmZmZmYgbm9kZTEgLSZndDsgbm9kZTKjrLfDzsrN6rPJbm9kZTG1xMv509C52M+1o6y007bTwdDW0M3Ls/Zub2RlMzxsaT7Tw9Payc/OxM/gzay1xLe9t6i3w87Kbm9kZTM8bGk+1+66873hufvI58/Co7oKPGJsb2NrcXVvdGU+Cgo8cHJlIGNsYXNzPQ=="brush:sql;">(1)–[KNOWS,2]–>(4) (1)–[KNOWS,1]–>(3) (1)–[KNOWS,0]–>(2) (1)–[KNOWS,1]–>(3)–[KNOWS,5]–>(7) (1)–[KNOWS,1]–>(3)–[KNOWS,4]–>(6) (1)–[KNOWS,1]–>(3)–[KNOWS,3]–>(5) Neo4j与关系型数据库的区别

    其实通过上述的讲解,相信大家都对neo4j与RDBMS(Relational Database Management System)的区别有了一定的认识,现在再用下面的表&#26684;来重新整理一下:

    Neo4j RDBMS
    允许对数据的简单且多样的管理 高度结构化的数据
    数据添加和定义灵活,不受数据类型和数量的限制,无需提前定义 表&#26684;schema需预定义,修改和添加数据结构和类型复杂,对数据有严&#26684;的限制
    常数时间的关系查询操作 关系查询操作耗时
    提出全新的查询语言cypher,查询语句更加简单 查询语句更为复杂,尤其涉及到join或union操作时

    最后再以下面两张图来展示一下两者在查询关系时的区别:\RDBMS\Neo4j

    关于Neo4j具体的安装和使用,不是文章的重点,如果想要真正上手用Neo4j,可以到Neo4j官网上面有很多资料



推荐阅读
  • 本文深入探讨了分布式文件系统的核心概念及其在现代数据存储解决方案中的应用,特别是针对大规模数据处理的需求。文章不仅介绍了多种流行的分布式文件系统和NoSQL数据库,还提供了选择合适系统的指导原则。 ... [详细]
  • 时序数据是指按时间顺序排列的数据集。通过时间轴上的数据点连接,可以构建多维度报表,揭示数据的趋势、规律及异常情况。 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 本文深入探讨了NoSQL数据库的四大主要类型:键值对存储、文档存储、列式存储和图数据库。NoSQL(Not Only SQL)是指一系列非关系型数据库系统,它们不依赖于固定模式的数据存储方式,能够灵活处理大规模、高并发的数据需求。键值对存储适用于简单的数据结构;文档存储支持复杂的数据对象;列式存储优化了大数据量的读写性能;而图数据库则擅长处理复杂的关系网络。每种类型的NoSQL数据库都有其独特的优势和应用场景,本文将详细分析它们的特点及应用实例。 ... [详细]
  • Oracle字符集详解:图表解析与中文乱码解决方案
    本文详细解析了 Oracle 数据库中的字符集机制,通过图表展示了不同字符集之间的转换过程,并针对中文乱码问题提供了有效的解决方案。文章深入探讨了字符集配置、数据迁移和兼容性问题,为数据库管理员和开发人员提供了实用的参考和指导。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 本文深入解析了Spring Cloud路由网关Zuul的核心功能及其典型应用场景。通过对方志朋老师教材的学习和实践,详细探讨了Zuul在微服务架构中的重要作用,包括请求路由、过滤器链管理以及服务动态扩展等关键特性。同时,结合实际案例,展示了Zuul在高并发和复杂业务场景下的应用优势,为读者提供了全面的技术参考。 ... [详细]
  • 深入解析Redis中五大数据类型的实用应用场景与技巧
    本文将深入探讨Redis中五大核心数据类型的实际应用场景与使用技巧。通过详尽的分析和示例,帮助读者理解每种数据类型的特性和最佳实践,内容涵盖广泛,步骤清晰,细节处理得当,旨在为开发者提供全面的指导。 ... [详细]
  • 在CentOS上部署和配置FreeSWITCH
    在CentOS系统上部署和配置FreeSWITCH的过程涉及多个步骤。本文详细介绍了从源代码安装FreeSWITCH的方法,包括必要的依赖项安装、编译和配置过程。此外,还提供了常见的配置选项和故障排除技巧,帮助用户顺利完成部署并确保系统的稳定运行。 ... [详细]
  • 开发心得:利用 Redis 构建分布式系统的轻量级协调机制
    开发心得:利用 Redis 构建分布式系统的轻量级协调机制 ... [详细]
  • NoSQL数据库,即非关系型数据库,有时也被称作Not Only SQL,是一种区别于传统关系型数据库的管理系统。这类数据库设计用于处理大规模、高并发的数据存储与查询需求,特别适用于需要快速读写大量非结构化或半结构化数据的应用场景。NoSQL数据库通过牺牲部分一致性来换取更高的可扩展性和性能,支持分布式部署,能够有效应对互联网时代的海量数据挑战。 ... [详细]
  • Linux学习精华:程序管理、终端种类与命令帮助获取方法综述 ... [详细]
  • 为何Serverless将成为未来十年的主导技术领域?
    为何Serverless将成为未来十年的主导技术领域? ... [详细]
  • 本书《.NET Core 2.* 开发者指南》是面向开发者的全面学习与实践手册,涵盖了从基础到高级的各个层面。书中详细解析了 .NET Core 的核心概念,包括如何创建 .NET Core 网站,并通过视频教程直观展示操作过程。此外,还深入探讨了 Startup 类的作用、项目目录结构的组织方式以及如何在应用中使用静态文件等内容。对于希望深入了解 .NET Core 架构和开发技巧的开发者来说,本书提供了丰富的实践案例和详尽的技术指导。 ... [详细]
author-avatar
安琪儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有