热门标签 | 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官网上面有很多资料



推荐阅读
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • GAMETECH腾讯云游戏行业技术沙龙成都站圆满落幕
    11月13日,由腾讯云主办、游戏茶馆协办的2020年首场GAME-TECH腾讯云游戏行业技术沙龙在成都圆满落幕。本次沙龙邀请了腾讯云游戏行业解决方案总监宋永周、腾讯云游戏行业高级解决方案架构师曾梓恩、腾讯云游戏行业高级产品架构师郑晓曦、腾讯云游戏行业高级解决方案架构师温球良和天美L1(王者荣耀)服务器技术副总监杨光,为参会同行们带来了干货满满的技术建议。本文介绍了腾讯云游戏云的优势和为不同游戏研运场景提供的服务。腾讯云在中国游戏云服务市场领跑,成为众多游戏开发者的合作伙伴。 ... [详细]
  • 【转】腾讯分析系统架构解析
    TA(TencentAnalytics,腾讯分析)是一款面向第三方站长的免费网站分析系统,在数据稳定性、及时性方面广受站长好评,其秒级的实时数据更新频率也获得业界的认可。本文将从实 ... [详细]
  • 博客_2018年博客总结
    本文由编程笔记#小编为大家整理,主要介绍了2018年博客总结相关的知识,希望对你有一定的参考价值。前言     ... [详细]
  • 前面刚有AWS开战MongoDB,双方“隔空互呛”,这厢又曝出2亿+简历信息泄露——MongoDB的这场开年似乎“充实”得过分了些。长期以来,作为“最受欢迎的NoSQL数据库”,M ... [详细]
  • 数据库基本介绍
    1、数据库基本知识概念:数据库:database(DB),是一种存储数据的仓库数据库是根据数据结构组织、存储和 ... [详细]
  • hackingTeam是如何被黑的
    hackingTeam是如何被黑的 ... [详细]
  • 什么是堡垒机?堡垒机是一个主机系统,其自身通常经过了一定的加固,具有较高的安全性,可抵御一定的攻击,其作用主 ... [详细]
  • 未来几年,商业智能的大趋势介绍
    1.数据科学家将消亡熟悉数据分析将是普通业务人员的基本技能,能利用好数据价值去做规划的企业组织将更成功,忽略数据重要性的将被逐渐淘汰。2.云端商业智 ... [详细]
  • MySQL:互联网公司常用 分库分表
    本文目录一、数据库瓶颈IO瓶颈CPU瓶颈二、分库分表水平分库水平分表垂直分库垂直分表三、分库分表工具四、分库分表步骤五、分库分表问题非partit ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了记录一次MySQL两千万数据的大表优化解决过程,提供三种解决方案相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 《Python3 网络爬虫开发实战》:高效实用的 MongoDB 文档存储
    NoSQL,全称NotOnlySQL,意为不仅仅是SQL,泛指非关系型数据库。NoSQL是基于键值对的,而且不需要经过SQL ... [详细]
  • 目录一、MySQL数据库1.简介2.用管理员身份登录3.密码相关操作4.SQL与NoSQL5.数据库重要概念二、MySQL基本语句1.基于库的增删改查2.基于表的增删改查3.基于记 ... [详细]
  • 在Ubuntu中安装MongoDB
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 架构师必读:日均500万数据,如何进行数据存储选型?
    点击上方关注我,选择“置顶或者星标”作者:麦田里的老农来源:https:zhuanlan.zhihu.comp37964096小编公司有一 ... [详细]
author-avatar
牛氏学道_246
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有