NoSQL 简介
- NoSQL,全名为 Not Only SQL,指的是非关系型的数据库。
- 随着访问量的上升,网站的数据库性能出现了问题,于是 nosql 被设计出来。
优缺点
- 优点:
(1) 高可扩展性
(2) 分布式计算
(3) 低成本
(4) 架构的灵活性,半结构化数据
(5) 没有复杂的关系
- 缺点:
(1) 没有标准化
(2) 有限的查询功能(到目前为止)
(3) 程序不直观
分类
类型 | 部分代表 | 特点 |
---|---|---|
列存储 | Hbase, Cassandra, Hypertable | 顾名思义,是按列存储数据的。最大的特点是方便存储结构化和半结构化数据,方便做数据压缩,对针对某一列或者某几列的查询有非常大的的 IO 优势。 |
文档存储 | MongoDB,CouchDB | 文档存储一般用类似 json 的格式存储,存储的内容是文档型的。这样也就有机会对某些字段建立索引,实现关系数据库的某些功能 |
key-value 存储 | Tokyo Cabinet / Tyrant , Berkeley DB, MemcacheDB, Redis | 可以通过 key 快速查询到其 value。一般来说,存储不管 value 的格式,照单全收。(Redis 包含了其他功能) |
图存储 | Neo4J | 图形关系的最佳存储。使用传统关系型数据库来解决的话性能低下,而且设计使用不方便 |
对象存储 | db4o, Versant | 通过类似面向对象语言的语法操作数据库,通过对象的方式存储数据 |
xml数据库 | Berkeley DB XML, BaseX | 高效的存储XML数据库,并支持 XML 的内部查询语法,比如 XQuery, XPath |
MongoDB 简介
- MongoDB 是一个基于分布式文件存储的 NoSQL 数据库
- 由 C++ 语言编写,运行稳定,性能高
- 旨在为 Web 应用提供可扩展性的高性能数据存储解决方案
MongoDB 特点
- 模式自由,可以把不同结构的文档存储在同一个数据库里
- 面向集合的存储:适合存储 JSON 风格文件的形式
- 完整的索引支持:对任何属性可索引
- 复制和高可用性:支持服务器之间的数据复制,支持 主-从 模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移
- 自动分片:支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器
- 丰富的查询:支持丰富的查询表达方式。查询指令使用 JSON 形式的标记,可轻易查询文档中的内嵌的对象及数组
- 快速就地更新:查询优化器会分析查询表达式,并生成一个高效的查询计划
- 高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)
基本操作
- MongoDB 将数据存储为一个文档,数据结构由键值 (key=>value) 对组成。
- MongoDB 文档类似于 JSON 对象,字段值可以包含其他文档、数组、文档数组
- 安装管理 mongodb 环境
- 完成数据库、集合的管理
- 数据的增加、修改、删除、查询
名词
SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
---|---|---|
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据库记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
table joins | 表连接,MongoDB不支持 | |
primary key | primary key | 主键,MongoDB 自动将 _id 字段设置为主键 |
- 三元素:数据库、集合、文档
集合就是关系型数据库中的表
文档对应着关系数据库中的行
- 文档,就是一个对象,由键值对构成,是 json 的扩展 Bson 形式。
{'name':'JayChou', 'gender':'男'}
- 集合:类似于关系型数据库中的表,存储多个文档,结构不固定,如可以存储如下文档在一个集合中
{'name':'guojing', 'gender':'男'}
{'name':'huangrong', 'age':18}
{'book':'shuihuzhuan', 'heros':108}
- 数据库:是一个集合的物理容器,一个数据库中可以包含多个文档
- 一个服务器通常有多个数据库
服务端 - mongod
- 配置文件在 /etc/mongod.conf
- 默认端口是 27017
- 启动:
sudo service mongod start
- 停止:
sudo service mongod stop
- 重启:
sudo service mongod restart
客户端 - mongo
- mongo 这个 shell 就是 mongodb 的客户端,同时也是一个 js 编译器
mongo
- 命令
db
- 查看当前数据库名称
db.stats()
- 查看当前数据库信息
- 终端退出连接
exit
或 Ctrl+C
- GUI 客户端:robomongo