图形数据库(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), ...
随机推荐
- 类的成员函数指针和mem_fun适配器的用法
先来看一个最简单的函数: void foo(int a) { cout << a << endl; } 它的函数指针类型为 void (*)(int); 我们可以这样使用: v ...
- 解决log4j.xml问题http//jakarta.apache.org/log4j/ uri is not registered
在Eclipse中,配置log4j.xml出现"http //jakarta.apache.org/log4j/ uri is not registered"的错误信息. 原始的l ...
- UUID(即GUID)
UUID(GUID)是Cocoa Touch提供的一种生成唯一标识的机制.类型为CFUUIDRef的对象可以代表UUID,UUID是基于当前时间.计数器和硬件标识(通常是以太网卡的MAC地址)等数据计 ...
- 【整理】mysql中information_schema.tables字段说明
[整理]mysql中information_schema.tables字段说明 2016-05-04 16:47:50| 分类: 默认分类|举报|字号 订阅 下载LOFTER我的照片书 | ...
- hdu 4454 Stealing a Cake(计算几何:最短距离、枚举/三分)
题意:已知起点.圆.矩形,要求计算从起点开始,经过圆(和圆上任一点接触即可),到达矩形的路径的最短距离.(可以穿过园). 分析:没什么好的方法,凭感觉圆上的每个点对应最短距离,应该是一个凸函数,用三分 ...
- 查看Android源码和源码布局
一.查看源码 1.https://github.com/android 2.http://grepcode.com/project/repository.grepcode.com/java/ext/c ...
- CentOS7 安装 Node.js
1.首先安装node.js 的版本管理工具 NVM,执行以下命令: curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.32.1/ ...
- ubuntu 16.04查询文件安装目录
dpkg -L filename dpkg -l | grep filename whereis filename find / -name filename
- PHP -- 问题
@.源码安装,最开始,自己通过 ./config make make install三步,啥参数也没加,安装好之后,发现/usr/local/php下就一个man文件夹,死都没找到php-fpm之 ...
- Hibernate 表连接hql语句
现有两个表 user 表 和 VIPcard 表 UserVo user VIPcardVo 中含有 UserVo user select v from VIPCardVo v left join ...