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度关系查找等 很多时候需要对整个图做计算才能得出需要的信息,而且这种结构不太好做分布式式的集群方案
相关推荐
松树戈3 分钟前
PostgreSQL使用LIKE右模糊没有走索引分析&验证
数据库·postgresql
文牧之10 分钟前
PostgreSQL 常用日志
运维·数据库·postgresql
TE-茶叶蛋34 分钟前
Redis 原子操作
数据库·redis·缓存
Linux运维老纪37 分钟前
Python文件操作及数据库交互(Python File Manipulation and Database Interaction)
linux·服务器·数据库·python·云计算·运维开发
Bruce_Liuxiaowei43 分钟前
MCP Python SDK构建的**SQLite浏览器**的完整操作指南
数据库·python·sqlite
数据与人工智能律师1 小时前
正确应对监管部门的数据安全审查
大数据·网络·数据库·人工智能·区块链
2401_897930061 小时前
什么是非关系型数据库
数据库·oracle
鱼丸丶粗面1 小时前
Python 读取 txt 文件详解 with ... open()
linux·数据库·python
拾荒者.1261 小时前
设计一个关键字统计程序:利用HashMap存储关键字统计信息,对用户输入的关键字进行个数统计。
数据库·python·mysql
encoding-console1 小时前
欧拉环境(openEuler 22.03 LTS SP3)安装移动磐维数据库(PanWeiDB_V2.0-S2.0.2_B01)步骤
数据库·虚拟机·欧拉·磐维数据库