MongoDB初识

原创 2013年12月05日 11:28:40
MongoDB是一个高性能,开源,无模式的文档型数据库。属于NoSQL,即Not only SQL,指非关系型数据库。

飞关系型数据库特点:非关系型、分布式、开源、水平可扩展。主要应用与大规模web使用,如:贴吧类似的东西。

先解释下非关系型数据库:

关系模型由关系数据结构、关系操作集合、关系完整性约束三部分组成。而非关系数据库是BSON存储格式,key/value型,就是想怎么存怎么存。如:{“hello":"world"}。没有关系型数据库的事务性约束(也可以实现事务,效率会下降),没有关系型复杂的范式结构。实现

1.High perfirmance 对数据库高并发读写的需求
2.Huge Storage -对海量数据的高效率存储和访问的需求
3.High Sclability&&Hign Availability-对数据库的高可扩展性和高可用性的需求

与关系型对比如下:
MongDB         关系型数据库
文档(document) 行(row)
集合(collection) 表(table)
数据库(database) 数据库(database)



MongoDB特点:(from 百度文库)

  • 面向集合存储,易于存储对象类型的数据。
  • 模式自由
  • 支持动态查询
  • 支持完全索引,包含内部对象
  • 支持查询
  • 支持复制和故障恢复
  • 使用高效的二进制数据存储,包括大型对象(如视频等)
  • 自动处理碎片,以支持云计算层次的扩展性。
  • 支持Python,Php,ruby,java,c,C#,js,perl以及C++语言的驱动程序
  • 文件存储格式为BSON(一种JSON的扩展)
  • 可通过网络访问
功能:
  • 面向对象的存储:适合存储对象以及JSON形式的数据
  • 动态查询:MongoDB支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易的查询文档中内嵌的对象及数组。
  • 完整的索引支持:包括文档内嵌对象及数组。MongoDB的查询优化器会分析查询表达式并生成一个高效的查询计划。
  • 查询监视:MonogoDB包含一系列监视工具用于分析数据库操作的性能。
  • 复制及自动故障转移:MongoDB数据库支持服务器之间的数据复制,支持主从模式及服务器之间的互相复制。复制的主要目标是提供冗余及自动故障转移
  • 高效的传统存储方式:支持二进制数据及大型对象(如照片或者图片)
  • 自动分片一直吃云级别的伸缩性:自动分片功能支持水平的数据及集群,可动态添加额外的机器。
适用场合:
  • 网站数据:非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
  • 缓存:由于性能很高,MongoDB也适合作为信息基础设施的缓存层,在系统重启之后,由MongoDB搭建的持久化缓存层可以避免下层的数据源过载。
  • 大尺寸,低价值的数据。低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储  
  • 高伸缩性的场景:MongoDB  非常适合由数十或数百台服务器组成的数据库。MongoDB的路线图中已经包含对 MapReduce 引擎的内置支持
  • 用于对象及 JSON 数据的存储:MongoDB 的 BSON 数据格式非常适合文档化格式的存储及查询

相关文章推荐

初识MongoDB 常用命令

shell操作数据库:  1.  超级用户相关:         1. #进入数据库admin          use admin         2. #增加或修改用户密码          db...

nosql篇mongodb初识与安装整理以及与关系型数据库对比

年前曾经写过关于mongodb的安装,但是后来有朋友弹窗说安装后遇到服务无法启动,在此将windows下以及Linux下的安装重新整理,顺便把会遇到的一些问题的解决方法写出来,其实mongodb的安装...

1.初识MongoDB

写在前面        最近在研究MongoDB,用过mysql,也用过MSSQL,oracle没用过,但他们都是基于SQL的、基于表的关系型数据库。懂其一,而他的都能略知一二。而MongoDB...

初识mongoDB

mongoDB是近几年新兴起的一种非关系型数据库(NoSQL),其具有灵活的数据存储方式。数据存储采用bson格式,可以存储比较复杂的数据类型。 相对于传统的数据库,mongoDB具有如下特性: ...
  • jjt_zaj
  • jjt_zaj
  • 2016年09月06日 13:40
  • 113

mongoDB初识

NoSQL(not only sql)非关系型数据库:随着web2.0的快速发展,数据量的加大,关系型数据库已经不能满足需求.mongoDB1.特点: - 易于使用:面向文档 - 易于扩展:纵...

初识Mongodb

mongoDB从入门到X 开一个mongodb系列,从安装到开发(java)的一个过程,现在也算略微懂一点技术,怎么去入门一门技术,分享下自己的学习的过程,下面是mongodb系列的第一个系列----...

Windows下mongoDb 安装、启动和初识

Windows下mongoDb 安装、启动和初识1.下载安装包:https://www.mongodb.com/download-center#community 下载下来的文件名mongodb...

MongoDB 初识(一)

第一步:下载MongoDBMongoDB官方网站,根据自己的操作系统进行选择适应的版本即可。第二步:新建目录“D:\MongoDB\bin”,解压下载到的安装包,找到bin目录下面全部.exe文件,拷...

初识mongodb数据库

1:MongoDB数据库简单介绍: MongoDB是一个高性能 ,开源 ,无模式的文档型数据库,它在许多场景下可用于替代传统的关系型数据库或键/值存储模式。MongoDB是用C++开发。 2:什么时...
  • zjhh116
  • zjhh116
  • 2012年01月18日 18:20
  • 745

MongoDB初识

近年来数据库界最红的无疑是noSQL了,大佬oracle也开始搞了。对于非关系型数据库我还不是很了解,因此开始学习比较好上手的mongoDB好了。定时的做笔记也是学习的十分好的习惯。      ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MongoDB初识
举报原因:
原因补充:

(最多只允许输入30个字)