|
一、NOSQL是什么
NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL"。指的是非关系型的数据库,是对不同于传统的关系型数据库的数据库管理系统的统称。
在现代的计算系统上每天网络上都会产生庞大的数据量,这些数据有很大一部分是由关系数据库管理系统(RDMBSs)来处理,关系模型是非常适合于客户服务器编程,远远超出预期的利益,今天它是结构化数据存储在网络和商务应用的主导技术。NoSQL 是一项全新的数据库革命性运动,发展至今年趋势越发高涨。学习了解一下很有必要。
NoSQL 数据库分类:
| 类型 |
部分代表
|
特点 |
| 列存储 |
Hbase
Cassandra
Hypertable
|
顾名思义,是按列存储数据的。最大的特点是方便存储结构化和半结构化数据,方便做数据压缩,对针对某一列或者某几列的查询有非常大的IO优势。
|
|
文档存储
|
MongoDB
CouchDB
|
文档存储一般用类似json的格式存储,存储的内容是文档型的。这样也就有有机会对某些字段建立索引,实现关系数据库的某些功能。
|
|
key-value存储
|
Tokyo Cabinet / Tyrant
Berkeley DB
MemcacheDB
Redis
|
可以通过key快速查询到其value。一般来说,存储不管value的格式,照单全收。(Redis包含了其他功能)
|
|
图存储
|
Neo4J
FlockDB
|
图形关系的最佳存储。使用传统关系数据库来解决的话性能低下,而且设计使用不方便。
|
|
对象存储
|
db4o
Versant
|
通过类似面向对象语言的语法操作数据库,通过对象的方式存取数据。
|
|
xml数据库
|
Berkeley DB XML
BaseX
|
高效的存储XML数据,并支持XML的内部查询语法,比如XQuery,Xpath。
|
mongodb是面向文档存储的数据,把数据保存为一篇篇文档。
二、什么是MongoDB
MongoDB 是由C++语言编写的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档。MongoDB是一个支持基于分布式文件存储的数据库。
三、MongoDB 概念与SQL比较
在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。
下表将帮助您更容易理解Mongo中的一些概念:
| SQL术语/概念 |
MongoDB术语/概念 |
解释/说明 |
|---|
| database |
database |
数据库 |
| table |
collection |
数据库表/集合 |
| row |
document |
数据记录行/文档 |
| column |
field |
数据字段/域 |
| index |
index |
索引 |
| table joins |
|
表连接,MongoDB不支持 |
| primary key |
primary key |
主键,MongoDB自动将_id字段设置为主键 |

比较关系型数据库
| RDBMS |
MongoDB |
|---|
| 数据库 |
数据库 |
| 表格 |
集合 |
| 行 |
文档 |
| 列 |
字段 |
| 表联合 |
嵌入文档 |
| 主键 |
主键 (MongoDB 提供了 key 为 _id ) |
| 数据库服务和客户端 |
|---|
| Mysqld/Oracle |
mongod |
| mysql/sqlplus |
mongo |
四、MARK一下,下次再记录 |