6、NoSQL的四大分类

6、NoSQL的四大分类

  1. kv键值对

    不同公司不同的实现

    • 新浪:Redis
    • 美团:Redis+Tair
    • 阿里、百度:Redis+memcache
  2. 文档型数据库(bson格式和json一样)

    • MongoDB
      • MongoDB是一个基于分布式文件存储的数据库,一般用于存储一些文档,C++编写,Redis也是用C编写的,而且Redis是单线程的。
      • MongoDB是一个介于关系型数据库和非关系型数据库的中间产品!MongoDB是非关系型数据库中功能最丰富,最像关系型数据库的。
    • CouchDB:国外的不做了解
  3. 列存储数据库:之前遇到的数据库都是以行存储的数据库,使用列存储数据库是非常方便的因为毕竟改行和改列是完全不一样的。

    • HBase
    • 分布式文件系统
  4. 图形关系数据库:这种类型的数据库并不是存放图片的,而是存放一些关系的

    • 不是用来存储图形的,而是存储的关系,比如:朋友圈、社交网络、广告推荐!
    • Neo4j,infoGrid

四者的对比

分类 Example举例 典型应用场景 数据模型 优点 缺点
键值对(key-value) Tokyo cabinet/tyant,Redis,voldemonrt,Oracle BDB 内容缓存,主要用于处理大数据的高访问负载,也用于一些日志系统等等 key指向value的键值对,通常用hash table来实现 查找速度快 数据无结构化、通常只被当做字符串或者二进制数据
列存储数据库 Cassandra,HBase,Ralk 分布式的文件系统 以列簇式存储,将同一列数据存在一起 查找速度快,可扩展性强,更容易进行分布式扩展 功能相对局限
文档型数据库 CouchDB,MongoDB web应用(与key-Value类似,Value是结构化的,不同的是数据库能够了解Value的内容) key-Value对应的键值对,Value为结构化数据 数据结构要求不严格,表结构可变,不需要像关系型数据库一样需要预先定义表结构 查阅性不高,而且缺乏统一的查询语法
图形(Graph)数据库 Neo4j,InfoGrid,Infinite Graph 社交网络、推荐系统等,专注于构建关系图谱 图结构 利用图结构相关算法,比如最短路径寻址N度关系查找等 很多时候需要对整个图做计算才能得出需要的信息,而且这种结构不太好做分布式式的集群方案
相关推荐
TDengine (老段)4 分钟前
TDengine 中的日志系统
java·大数据·数据库·物联网·时序数据库·tdengine·iotdb
kfepiza1 小时前
Debian编译安装mysql8.0.41源码包 笔记250401
数据库·笔记·mysql·debian·database
tjfsuxyy1 小时前
SqlServer整库迁移至Oracle
数据库·oracle·sqlserver
老王笔记1 小时前
MySQL统计信息
数据库·mysql
无名之逆2 小时前
[特殊字符] Hyperlane 框架:高性能、灵活、易用的 Rust 微服务解决方案
运维·服务器·开发语言·数据库·后端·微服务·rust
爱的叹息2 小时前
MongoDB 的详细解析,涵盖其核心概念、架构、功能、操作及应用场景
数据库·mongodb·架构
爱的叹息3 小时前
华为高斯(GaussDB)数据库中 Range、List、Hash三种分区方式 的完整SQL示例及增删改查操作,并附上总结对比表格
数据库·哈希算法·gaussdb
kfepiza4 小时前
Debian用二进制包安装mysql8.0.41 笔记250401
数据库·笔记·mysql·debian·database
在努力的韩小豪4 小时前
B树和B+树的区别(B Tree & B+ Tree)
数据结构·数据库·b树·b+树·索引·数据库索引