图数据库与其他 NoSQL 数据库的对比

1.3 图数据库与其他 NoSQL 数据库的对比

为了克服关系数据库在大型企业级应用中的弊端, NoSQL 数据库逐渐流行起来。 NoSQL 数据库专注于解决大规模数据集合、多重数据种类带来的挑战,尤其是大数据应用难题。同时 NoSQL 数据库的多样化也提供了多种不同的数据模型解决方案,每个解决方案都可以应用到不同的项目用例中。显然, Neo4j 就是 NoSQL 中可以提供图数据模型的典型代表。

1.3.1 其他 NoSQL 数据库的弊端

目前大部分 NoSQL 类数据库的数据存储形式都是基于集合的,数据按照集合被划分开,比如文档数据库中的文档。 NoSQL 数据库的数据存储在不连贯的集合中,这使得数据之间的相互连接、建立关系变得困难。

要实现类似关系数据库的外键功能,通常人们会将某个数据集合直接嵌入到另一个数据集合中来实现两者之间的从属关系,但很明显这样创建数据集合之间的关系要付出很大的存储开销。

分类数据类型优势劣势典型应用场景
键值数据库哈希表查找速度快数据无结构化,通常只被当作字符串或者二进制数据内容缓存,主要用于处理大量数据的高访问负载,也用于一些日志系统等
列存储数据库列式数据存储结构查找速度快,支持分布横向扩展,数据压缩率高功能相对受限分布式文件系统
文档型数据库键值对扩展数据结构要求不严格,表结构可变,不需要预先定义表结构查询性能不高,缺乏统一的查询语法Web应用
图数据库节点和关系组成的图利用图结构相关算法。比如最短路径,节点度关系查找等可能需要对整个图做计算, 不利于图数据分布存储社交网络、 推荐系统、意向图、消费图、兴趣图、关系图谱等
分类性能可扩展性灵活性复杂性功能性
键值数据库可变(无)
列存储数据库一般很少
文档型数据库可变(高)可变(低)
图数据库可变可变图论
关系数据库可变可变一般关系代数
1.3.2 将键值对存储与图数据库相关联

如下图所示,键值(Key-Value)存储数据库,其数据按照键值对的形式进行组织、索引和存储,类似 Java 中的 map ,它适合不涉及过多数据关系的应用。因为能有效减少读写磁盘的次数,所以其性能非常高。
在这里插入图片描述

如果将这些键值对相互关联,就可以得到一个图结构。通过这个图结构,可以表达数据之间的复杂关系,如下图所示。

在这里插入图片描述

1.3.3 将文档存储与图数据库相关联

文档存储的层次化结构可容纳许多无模式的数据,可以轻松地将数据存储为树状结构。虽然树也是一种图形,但树只能表达从下到上的从属关系,如下图所示。

在这里插入图片描述

在树状存储结构中总会出现多次被嵌入的冗余数据,这增加了更新数据的困难,同时也难以确保数据的一致性。如果我们将冗余的数据去掉,然后用图结构将存在相互关系的数据相关联,数据冗余的问题就解决了,并且数据之间的关系变得更直观,如下图所示。

在这里插入图片描述

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我真的不是cjc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值