MongoDB(一)——简介
这两天简单学习了一下MongoDB数据库,属于NoSQL类型数据库的一种,先简单宏观的看一下NoSQL的相关知识和MongoDB的基础知识。
NoSQL是Not Only SQL的缩写,它指的是非关系型数据库,即有别于Oracle,mysql,sqlserver等经常使用的关系型数据库。它是以key-value形式存在,即我们熟悉的JSON数据形式。
发展:NoSQL是随着互联网Web2.0站点的兴起,传统的关系数据库在应付web2.0站点,特别是超大规模数据量和高并发的SNS类型的web2.0纯动态网站已经显得力不从心。暴露了很多难以克服的问题。而NoSQL也就是为了应付这些问题而出现,并不断发展着。
最開始是google公司的Bigtable,淘宝数据平台的Tair,视觉中国站点的MongoDB等都代表NoSQL的不断发展。
NoSQL发展迅速的原因:随着互联网的不断发展,各种类型的应用层出不穷。所以导致在这个云计算的时代。对技术提出了很多其它的需求。尽管关系型数据库已经在业界的数据存储方面占领不可动摇的地位,可是由于其天生的几个限制,使其难以满足以上的几个需求:扩展困难,读写慢,成本高,有限的支撑容量。
可是NoSQL关注的对数据高并发读写和对海量数据的存储等,与关系型数据库相比,它们在架构和数据模型方面做了削弱,而在扩展和并发等方面做了增强突出。
特点:非关系型的,分布式的。开源的,水平可扩展的。
长处:扩展简单。读写更加高速,成本更加低廉。灵活的数据模型。
不足:不提供的对SQL的支持,支持的特性不够丰富,如今的产品相比关系型数据库不够成熟。
总而言之NoSQL的出现是紧随时代的步伐——大数据。云计算而诞生,并不断发展的,是处在一个成长中的。
下边简单看一下它的比較成熟的一个产品MongoDB的简介。
MongoDB 的名称取自“humongous” (巨大的) 的中间部分。足见mongodb 的宗旨在处理大量数据上面。是一个可扩展、高性能的下一代数据库,由 C++语言编写,旨在为web 应用提供可扩展的高性能数据存储解决方式。
Mongo DB很好的实现了面向对象的思想(OO思想),在Mongo DB中每一条记录都是一个Document对象。MongoDB最大的优势在于全部的数据持久操作都无需开发者手动编写SQL语句,直接调用方法就能够轻松的实现CRUD操作。
好,看一下它有什么特性,依据这些特性我们能够选择什么时候用它:高性能、易部署、易使用,存储数据很方便是它的主要特点:
²模式自由,支持动态查询、全然索引。可轻易查询文档中内嵌的对象及数组
²面向文档存储,易存储对象类型的数据, 包括文档内嵌对象及数组
²高效的数据存储,支持二进制数据及大型对象(如照片和视频)
²支持复制和故障恢复;提供了主-从、主-主模式的数据复制及server之间的数据复制
²自己主动分片以支持云级别的伸缩性。支持水平的数据库集群,可动态加入额外的server
适用场景:
²适合作为信息基础设施的持久化缓存层
²适合实时的插入,更新与查询。并具备应用程序实时数据存储所需的复制及高度伸缩性
²Mongo 的 BSON 数据格式很适合文档化格式的存储及查询
²适合由数十或数百台server组成的数据库。由于 Mongo 已经包括了对 MapReduce 引擎的内置支持
不适用场景:
²要求高度事务性的系统
²传统的商业智能应用
² 复杂的跨文档(表)级联查询
综上,我们对NoSQL,MongoDB有了个宏观的理解,知道NoSQL出现并不断发展状态的原因,MongoDB的使用范围。好处短处等,这对于我们对此款软件的认识很重要,关系到我们技术选择的一关。就是认识人一样。我们是从总体容貌開始。然后随着不断的深入,在观察他们细节外貌。行为方式,生活习惯等等。学习一门技术也是这样。先了解他了。然后在開始一点点的学习技术,并随着使用次数的增多。不断的加深理解。不断的升华。
MongoDB(一)——简介的更多相关文章
- MongoDB数据库简介及安装
一.MongoDB数据库简介 简介 MongoDB是一个高性能,开源,无模式的,基于分布式文件存储的文档型数据库,由C++语言编写,其名称来源取自"humongous",是一种开源 ...
- MongoDB入门简介
MongoDB入门简介 http://blog.csdn.net/lolinzhang/article/details/4353699 有关于MongoDB的资料现在较少,且大多为英文网站,以上内容大 ...
- 2.MongoDB数据库简介
1).简介 MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. mongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系 ...
- MongoDB第一天(MongoDB的简介和安装)
MongoDB 简介 什么是 MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++语言编写.在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关 ...
- mongodb使用简介
mongodb简介 在使用nodejs时候,需要存储一些简单json数据的情况下,很多人会推荐使用mongodb.mongodb是一个文档型数据库,在 sql 中,数据层级是:数据库(db) -> ...
- mongoDB 数据库简介
背景概念-数据库类型 对比关系型数据库 优点 : 逻辑清晰.容易理解,结构类似表格 使用 sql 语句技术成熟,使用方便 数据一致性好,完整性好 关系型数据库比较成熟,可以使用一些复杂操作 缺点 : ...
- MongoDB入门教程二[MongoDB Shell 简介与使用]
MongoDB Shell 是MongoDB自带的JavaScript Shell,随MongoDB一同发布,它是MonoDB客户端工具,可以在Shell中使用命令与MongoDB实例交互,对数据库的 ...
- MongoDB入门---简介
最近呢,刚好有一些时间,所以就学习了一下新的数据库类型MongoDB.要想了解这个MongoDB,我们首先需要了解一个概念,那就是nosql(not only sql).一下就是官方的概念: NoSQ ...
- Mongodb之简介
MongoDB是一个基于分布式存储的数据库,由C++语言编写,旨在为WEB应用提供的可扩展的高性能数据存储解决. MongoDB是介于关系型数据库与非关系型数据库之间的产品,也是非关系型数据库中功能最 ...
随机推荐
- 公布项目到NPM
修己安人,内圣外王 近期,在开发Node项目过程中遇到了须要类jQuery深拷贝对象的问题.去Github找了半天,并没有符合的,于是,自己决定写一个(mixin.js),然后推送到NPM(查看Npm ...
- Android通过Intent.ACTION_CLOSE_SYSTEM_DIALOGS监听Home按键消息
Android对屏幕下方经常使用的四个按键消息处理是不一致的: 1.搜索按键的消息在onKeyDown或者onKeyUp中接收: 2.菜单按键的消息在onCreateOptionsMenu.onKey ...
- Shiro 学习应用(续)
在前面的文章中为大家介绍了 Shrio 的基础概念.可能比較笼统.没有深入到开发过程的一些问题.如今集中在本帖中归纳一下有关问题. FormAuthenticationFilter 表单过滤器 表单过 ...
- TLS握手
http://www.ruanyifeng.com/blog/2014/02/ssl_tls.html 1994年,NetScape公司设计了SSL协议(Secure Sockets Layer)的1 ...
- 分析性能瓶颈的视图:v$session_wait
这是一个寻找性能瓶颈的关键视图.它提供了任何情况下session在数据库中当前正在等待什么(如果session当前什么也没在做,则显示它最后的等待事件).当系统存在性能问题时,本视图可以做为一个起点指 ...
- 杂项-软件: VBA(Visual Basic for Applications)
ylbtech-杂项-软件: VBA(Visual Basic for Applications) VBA (Visual Basic宏语言) Visual Basic for Application ...
- HIT Software Construction Lab 2
2019年春季学期 计算机学院<软件构造>课程 Lab 2实验报告 姓名 刘帅 学号 班号 1703008 电子邮件 1609192321@qq.com 手机号码 目录 1 实验目标概 ...
- Rep Invariant and Abstraction Function
* According to the Reading 13 of MIT 6.005 course In order to finish Lab 2, in which the ps 2 gives ...
- Noip前紧急抢救
管他会不会,知道结论就好了 紧急抢救知识 斯特林数 第一类斯特林数 递推公式 \[ S[n][k]=(n-1)\times S[n-1][k]+S[n-1][k-1] \] 处理的问题是将n个数划分为 ...
- 转:Hibernate中Criteria和DetachedCriteria的完整用法
原文地址:http://blog.sina.com.cn/s/blog_667528fd0100rkrf.html 设计上可以灵活的根据 Criteria 的特点来方便地进行查询条件的组装.现在对 H ...