SQL到NoSQL概览性总结之一 数据库应用场景选型
数据库类型与实例 |
适合场景 |
不适合场景 |
场景举例 |
关系数据库 基于集合理论,具有行和列的二维表,严格使用类型 开源MySQL/MariaDB, PostgreSQL 商业:Oracle,DB2,SQL Server, Sybase |
l 数据具有类型 l 灵活查询。 l 即提前为组织的复杂性付出代价,以实现随后的查询灵活性 |
l 数据高度或者多层次的,无法提前指定模式 |
|
键值数据库 Redis Riak—类dynamo Memcached(membase..) BerkeleyDB Voldemort |
l 数据相关性不高 l 性能极高 |
l 缺乏索引和扫描功能,除了基本的CRUD外帮助不大 l 对于自由定义的查询无能为力 l 不适合复杂查询和聚合等 |
l 适合场景 Session信息 用户概要等信息 购物车 l 不适合场景 数据之间存在强关联 事务 根据value查询 Operations by Sets |
列型数据库 HBase Cassandra Hypertable |
l 横向扩展 l 列的添加容易 l 版本控制 |
l 基于你打算如何查询数据设计数据库模式 l 不仅对数据如何组成有一些想法,对如何使用数据也要预先知晓 |
l 适合场景 事件日志 CMS,博客 计数器 数据过时使用 l 不适合场景 |
文档型 MongoDB CouchDB |
l 每个对象有任意数量字段,对象可以作为值以任意深度嵌套到其他字段中 l 高度可变领域 l 很好的映射到OOP |
l 缺乏复杂的查询,如联接 |
l 适合场景 事件日志 CMS,博客 Web分析或者实时分析 电子商务 l 不适合场景 复杂事务 查询持续变化的聚合结构 |
图数据库 Neo4j(支持ACID事务) |
l 形式自由的网络应用,如社交网络 l 不需要将相似的对象划分共同组,只要可以在白板上建模就可以表示 l 场景如推荐引擎、ACL和地理数据 |
l 节点之间的高度关联,不适合网络分区 l 扩展性差,通常大容量数据存储在其他地方,而在图中只保存关系 |
l 适合场景 互联数据 路由、分发和基于位置的服务 推荐引擎 l 不适合场景 |
参考文献
《七周七数据库》
《NoSQL Distilled》
SQL到NoSQL概览性总结之一 数据库应用场景选型的更多相关文章
- SQL与NoSQL(关系型与非关系型)数据库的区别
永远正确的经典答案依然是:具体问题具体分析. 数据表VS.数据集 关系型和非关系型数据库的主要差异是数据存储的方式.关系型数据天然就是表格式的,因此存储在数据表的行和列中.数据表可以彼此关联协作存储, ...
- 数据库 --> SQL 和 NoSQL 的区别
SQL 和 NoSQL 的区别 一.概念 SQL (Structured Query Language) 数据库,指关系型数据库.主要代表:SQL Server,Oracle,MySQL(开源), ...
- 大数据学习资料之SQL与NOSQL数据库
这几年的大数据热潮带动了一激活了一大批hadoop学习爱好者.有自学hadoop的,有报名培训班学习的.所有接触过hadoop的人都知道,单独搭建hadoop里每个组建都需要运行环境.修改配置文件测试 ...
- SQL与NoSQL区别--商业SQL数据库衰落--oracle面临困境
转自:商用数据库之死:Oracle 面临困境 这二十年来,商业数据库市场仍然是 IT 行业最稳定.最具黏性的领域之一,Oracle.IBM 和微软三家厂商瓜分了 80% 的份额.然而,我们认为这个领域 ...
- 技术分享|SQL和 NoSQL数据库之间的差异:MySQL(VS)MongoDB
在当今市场上,存在各种类型的数据库,选择适合你业务类型的数据库对应用的开发和维护有着重要意义.本篇文章,将为大家分享SQL和NoSQL语言之间的区别,同时还将比较这两种类型的数据库,以帮助小伙伴们选择 ...
- SQL VS NoSQL 如何选择数据库
在前一篇文章中我们主要的讨论了SQL与NoSQL数据库之间的主要的差别.接下来,我们将会利用上一篇中的知识来确定在特定的场景中如何确定比较好的选择. 首先我们先来总结一下: SQL数据库: 使用表存 ...
- SQL vs NoSQL 没有硝烟的战争!
声明:本文译自SQL vs NoSQL The Differences,如需转载请注明出处. SQL(结构化查询语言)数据库作为一个主要的数据存储机制已经超过40个年头了.随着web应用和像MySQL ...
- SQL VS NoSQL
(关系型与非关系型)数据库的区别: 关系型和非关系型数据库的主要差异是数据存储的方式 1.1 数据表 VS 数据集 关系型数据天然就是表格式的,因此存储在数据表的行和列中.数据表可以彼此关联协作存储, ...
- SQL 到 NOSQL 的思维转变
转自:http://blogread.cn/it/article/3130?f=wb SQL 到 NOSQL 的思维转变 NOSQL系统一般都会宣传一个特性,那就是性能好,然后为什么呢?关系型数据库发 ...
随机推荐
- [开源]Google code Android开源项目(一)
[Android分享] [开源]Google code Android开源项目(一) [复制链接] 449122717 2 主题 2 好友 816 积分 No.4 中级开发者 升级 19.3 ...
- WordPress主题开发:优化标题
页面使用: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- 关于面试总结11-selenium面试题
前言 面试web自动化必然会问到selenium,问selenium相关的问题定位是最基本的,也是自动化的根本,所以面试离不开元素定位问题. 之前看到招聘要求里面说"只会复制粘贴xpath的 ...
- Convolutional Neural Networks at Constrained Time Cost(精读)
一.文献名字和作者 Convolutional Neural Networks at Constrained Time Cost,CVPR 2015 二.阅读时间 2015年6月30 ...
- java collection.frequency方法
collection.frequency方法,可以统计出某个对象在collection中出现的次数 比如: frequency(Collection<?> c, Object o) ...
- SqlServer 查看备份文件中逻辑文件信息的Sql语句
RESTORE FILELISTONLY FROM DISK = 'D:\All\DataBase\(2013-12-18)-1.bak' 用来查看备份文件中的逻辑文件信息. 相关信息:SqlServ ...
- ExtJS 4.2 教程-08:布局系统详解
ExtJS 4.2 系列教程导航目录: ExtJS 4.2 教程-01:Hello ExtJS ExtJS 4.2 教程-02:bootstrap.js 工作方式 ExtJS 4.2 教程-03:使用 ...
- 深入理解多线程(四)—— Moniter的实现原理
在深入理解多线程(一)——Synchronized的实现原理中介绍过关于Synchronize的实现原理,无论是同步方法还是同步代码块,无论是ACC_SYNCHRONIZED还是monitorente ...
- YAML文件简介
编程免不了要写配置文件,怎么写配置也是一门学问. YAML 是专门用来写配置文件的语言,非常简洁和强大,远比 JSON 格式方便. 本文介绍 YAML 的语法,以 JS-YAML 的实现为例.你可以去 ...
- golang的配置文件操作:viper
参考: 1.http://blog.51cto.com/13599072/2072753 2.https://studygolang.com/articles/14453 3.https://www. ...