图形数据库(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), ...
随机推荐
- 2.oracle分页,找到员工表中薪水大于本部门平均薪水的员工
ROWNUM的知识点 A ROWNUM依照oracle的默认机制生成. B rownum仅仅能使用<= <号,不能使用> >= rownum的实现机制 rownum表 ...
- Linux非阻塞IO(七)使用epoll重新实现客户端
使用poll与epoll的区别主要在于: poll可以每次重新装填fd数组,但是epoll的fd是一开始就加入了,不可能每次都重新加入 于是采用这种策略: epoll除了listenfd一开始就监听r ...
- jmap命令(Java Memory Map)的使用
jmap的使用能够參考: 官方文档 http://docs.oracle.com/javase/6/docs/technotes/tools/share/jmap.html 和这篇博客 http:// ...
- CSS——如何清除浮动
众所周知,平时在写HTML代码时,难免少不了使用Float样式,这样一来,假使您没有清除浮动,那么有浮动元素的父元素容器将元素将无法自动撑开.换句简单好理解的话来说,假如你在写CODE时,其中div. ...
- CSS字体中英文名称对照表(转)
在css文件中,我们常看到有些字体名称变成了乱码,这是由于网页开发者将中文字体的名字直接写成了中文,而css文件本身没有声明字符编码方式,查看时就出现了乱码.为了避免这种乱码状况出现,可以将css ...
- Directional Light,Ambient,Specular,光照感性认识...
- 【海盗派测试分析MFQ&PPDCS】读书笔记
使用脑图花了一张读书笔记,可能有点长
- ws 无法热替换的问题
这个坑自己踩过并且第二次就记录一下,因为一直习惯用ws, 使用热部署的时候发现无法自动同步热更新,找了很多方法,具体解决方式如下: webstorm默认保存在临时文件夹,根据下面路径将默认勾选项去除即 ...
- who 查看系统登录用户
who 查看所有登录用户 whoami 查看自己的登陆名 w users last
- Harvard数据库课程CS 265: Research Topics in Database Systems
CS 265: Research Topics in Database Systems Announcements Quiz 3 will be posted. Good luck! Quiz 2 h ...