数据库
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。
数据库是一门学科,专门做数据库运维的人叫Database Administrator,简称DBA,有的DBA指深入专研一种数据库。
文档数据
文档型数据这个名字中,“文档”两个字很容易误解。其实这个文档就是 bson 。bson 是 json 的超集,比如 json 中没法储存二进制类型,而 bson 拓展了类型,提供了二进制支持。mongodb 中存储的一条条记录都可以用 bson 来表示。所以你也可以认为,mongodb 是个存 bson 数据的数据库。
MongoDB简介
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
分布式算法指的是将一个大型的任务进行分解,将每一个小任务的执行结果组合起来,返回一个整体。
好处:
给其他任务提供了可执行的机会。
MongoDB 是非关系型数据库当中功能最丰富,最像关系型数据库的。
MongoDB优点
它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:
- 面向集合存储,易存储对象类型的数据。
- 模式自由。
- 支持动态查询
- 支持完全索引,包含内部对象。
- 支持查询
- 支持复制和故障恢复。
- 使用高效的二进制数据存储,包括大型对象(如视频等)。
- 自动处理碎片,以支持云计算层次的扩展性。
- 支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。
- 文件存储格式为BSON(一种JSON的扩展)。
数据库类型
关系型数据库(sql):Access mySql SqlServer oracle db2等。
非关系型数据库( NoSql ): MongoDB,Redis,HBase,CouchDB等。
关系型数据库 以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。
非关系型数据库与关系型数据库区别
非关系型数据库的优势:
-
性能
NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。 -
可扩展性
同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。
关系型数据库的优势:
-
复杂查询
可以用SQL语句方便的在多个表之间做非常复杂的数据查询。 -
事务支持
使得对于安全性能很高的数据访问要求得以实现。
总结:
数据库功能是用来存储数据的。
数据库分为关系系数据库和非关系型数据库(nosql)
关系型数据库是由表和表之间的关系组成的,nosql是由集合组成的,集合下面是很多的文档。
非关系型数据库文件存储格式为BSON(一种JSON的扩展)。