图形数据库(GraphDB)
Date: 2016-01-27
Title: 图形数据库-1
Published: true
Type: post
Excerpt:
Category: GraphDB
图形数据库(GraphDB)
如果您对此文章感兴趣,欢迎发邮件至andy.zhangtao@hotmail.com
何谓图形数据库
在我们生存的实际世界当中,到处都存在着"关系"。世界当中没有独立存在的事物,在我们身边充斥着大量的,相互交织的各种关系。
如果需要处理这些相互交织的关系数据,凭借关系型数据库是无法完成的。此时,就需要一种以关系为核心,并且可以高效存储,高效处理的数据库。
相对于图形数据库而言,关系型数据库虽然也可以计算这些"关系"数据,但计算的代价却是异常昂贵。得益于图形数据库天生以"关系"为核心,因此其在检索关系数据时非常高效,目前可以支持每颗CPU每秒处理百万次关系检索,效率比RDBMS高出好几个数量级。
那图形数据库会替代RDBMS吗?首先来说,两者适用场景不同。图形数据库更加侧重于处理海量数据下的,高度链接的关系拓扑关系和复杂的查询需求,而这些恰恰不是RDBMS的强项。
图形数据库使用的数据模型
如果读者接触过对象模型或者实体图,那么想必对下面的模型必然不陌生。在图形数据库模型中,一个实体称之为一个节点(node),每个node都有非常多的属性,这些属性通过key-value来表示。相同的node在不同的场景当中可以拥有不同的标签信息(lable)。而这些Lable信息,除了可以用来标记node之外,也可以用来附加一些metadata(例如索引信息或者约束信息等).
而在两个节点之间,有向并且语义清楚的连接就称之为关系。
通常来说,一个关系包括方向,类型,起点node和结束node四个要素。而对于node来说,一个关系则可以同时拥有多个属性。例如权重,代价,距离,级别,新鲜度或者优势度等等。因为在图形数据库当中,维护一条关系是一个代价非常小的事情,所以两个节点之间可以在不带来额外性能损失的情况下,拥有无限条的关系或者属性。
但有一点需要注意,尽管关系是有向的,但关系本身却不关心方向。只有node才会关心方向。
虽然关系很便宜,但在图形数据库当中却有一条铁的纪律:"不允许存在死链"。因为每条关系都必须存在起始node和结束node,所以用户无法在删除所有关系之前删除掉与之相关联的node。用户可以认为,一条存在的关系必然会连接两个存在的node。
图形数据库(GraphDB)的更多相关文章
- 图形数据库 Neo4j 开发实战
https://www.ibm.com/developerworks/cn/java/j-lo-neo4j/ Neo4j 是一个高性能的 NoSQL 图形数据库.Neo4j 使用图(graph)相关的 ...
- 图形数据库Neo4J简介
最近我在用图形数据库来完成对一个初创项目的支持.在使用过程中觉得这种图形数据库实际上挺有意思的.因此在这里给大家做一个简单的介绍. NoSQL数据库相信大家都听说过.它们常常可以用来处理传统的关系型数 ...
- neo4j-jersey分嵌入式和服务式连接图形数据库
原文载自:http://blog.csdn.net/yidian815/article/details/12887259 嵌入式: 引入neo4j依赖 <dependency> <g ...
- 图形数据库、NOSQL和Neo4j
简介 在众多不同的数据模型里,关系数据模型自80年代就处于统治地位,而且有不少实现,如Oracle.MySQL和MSSQL,它们也被称为关系数据库管理系统(RDBMS).然而,最近随着关系数据库使用案 ...
- 通过Spring Data Neo4J操作您的图形数据库
在前面的一篇文章<图形数据库Neo4J简介>中,我们已经对其内部所使用的各种机制进行了简单地介绍.而在我们尝试对Neo4J进行大版本升级时,我发现网络上并没有任何成型的样例代码以及简介,而 ...
- Neo4j 第二篇:图形数据库
在深入学习图形数据库之前,首先理解属性图的基本概念.一个属性图是由顶点(Vertex),边(Edge),标签(Lable),关系类型和属性(Property)组成的有向图.顶点也称作节点(Node), ...
- Linux下图形数据库Neo4j单机安装
Neo4j数据库简介 Neo4j 是一个NoSQL的图形数据库(Graph Database).Neo4j使用图(graph)相关的概念来描述数据模型,把数据保存为图中的节点以及节点之间的关系.很多应 ...
- NoSql图形数据库
NoSQL数据库可以按照它们的数据模型分成4类: 键-值存储库(Key-Value-stores); BigTable实现(BigTable-implementations); 文档库(Documen ...
- 图形数据库Neo4j基本了解
在深入学习图形数据库之前,首先理解属性图的基本概念.一个属性图是由顶点(Vertex),边(Edge),标签(Lable),关系类型和属性(Property)组成的有向图.顶点也称作节点(Node), ...
随机推荐
- 可移动磁盘显示0kb打不开怎么办
移动硬盘.U盘打不开怎么办 为了方便共享,大多数人都购买了移动硬盘.那么如果有一天,发现移动硬盘打不开了,怎么办?下面为大家介绍移动硬盘打不开的解决方法. 未格式化故障 第一步:双击盘符出现未格式 ...
- Ros 中的多线程
参考文献:http://blog.csdn.net/sinat_27554409/article/details/48446611 老王说ROS http://blog.csdn.net/yake ...
- Oracle 查询用户表信息,导入导出处理表空间不一致
select table_name,tablespace_name from user_tables t; //查询用户默认表空间信息 SELECT t.* FROM USER_USERS t; 导入 ...
- java读取clob字段的几种方法
http://cache.baiducontent.com/c?m=9f65cb4a8c8507ed4fece7631046893b4c4380143fd3d1027fa3c215cc790f1a06 ...
- view无限旋转
- (void) showRefreshAnimation { [UIView animateWithDuration: options:UIViewAnimationOptionCurveLinea ...
- centos安装pip Xvfb Selenium
pip安装命令: python -V wget https://bootstrap.pypa.io/get-pip.py python get-pip.py Xvfb安装命令: yum install ...
- 并发编程概述 委托(delegate) 事件(event) .net core 2.0 event bus 一个简单的基于内存事件总线实现 .net core 基于NPOI 的excel导出类,支持自定义导出哪些字段 基于Ace Admin 的菜单栏实现 第五节:SignalR大杂烩(与MVC融合、全局的几个配置、跨域的应用、C/S程序充当Client和Server)
并发编程概述 前言 说实话,在我软件开发的头两年几乎不考虑并发编程,请求与响应把业务逻辑尽快完成一个星期的任务能两天完成绝不拖三天(剩下时间各种浪),根本不会考虑性能问题(能接受范围内).但随着工 ...
- 借助Anyproxy实时监控接口调用次数和流量
监控接口调用次数,是为了测试客户端可能会异常频繁的调用服务端接口,出现性能问题. AnyProxy是一个开放式的HTTP代理服务器. github: https://github.com/alibab ...
- 【机器学习详解】SMO算法剖析(转载)
[机器学习详解]SMO算法剖析 转载请注明出处:http://blog.csdn.net/luoshixian099/article/details/51227754 CSDN−勿在浮沙筑高台 本文力 ...
- POJ 1654 area 解题
Description You are going to compute the area of a special kind of polygon. One vertex of the polygo ...