參考MongoDB权威指南,学习阶段。大家多多交流问题。持续更新本文

MongoDB的长处
MongoDB具有丰富的数据模型,是面向文档的数据库。

easy扩展。能够在多台server之间切割数据。

开发人员仅仅需专注于编写应用。假设须要更大的数据。仅仅需在集群中加入新机器,然后让数据库来处理剩下的事情。

具有丰富的功能,比方索引,存储JavaScript,聚合,固定集合。文件存储。

不支持联接(join)和复杂的多行事物。

卓越的性能是MongoDB的主要目标,默认的存储引擎使用了内存映射文件。将内存管理工作交给操作系统。

简便的管理,MongoDB尽量让server自己管理数据库。除了启动数据库server之外。差点儿没有什么必要的管理操作。

假设主server挂掉,会自己主动切换到备server上。

MongoDB的下载和安装
首先去MongoDB官网,依据系统型号选择要下载的版本号。这里以centos64位为例
    #下载

    > wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.4.tgz
> tar -zxvf mongodb-linux-x86_64-3.0.4.tgz
> mv mongodb-linux-x86_64-3.0.4 /usr/local/mongodb
> cd /usr/local/mongodb
> mkdir db
> mkdir logs > vim bin/mongodb.conf #加入下面内容 dbpath=/usr/local/mongodb/db
logpath=/usr/local/mongodb/logs/mongodb.log
port=27017
fork=true #又一次绑定mongodb的配置文件地址和訪问IP > /usr/local/mongodb/bin/mongod --bind_ip localhost -f /usr/local/mongodb/bin/mongodb.conf #启动MongoDB
> /usr/local/mongodb/bin/mongod --config /usr/local/mongodb/bin/mongodb.conf #測试是否开启成功进入mongodb的shell模式
> /usr/local/mongodb/bin/mongo
> show dbs
#没有异常的话安装启动成功了。
MongoDB的基本概念

文档是MongoDB中数据的基本单元,很相似关系型数据库中的行。

相似地。集合能够看做是没有模式的表。

MongoDB的单个实例能够容纳多个独立的数据库。每个都有自己的集合和权限。

MongoDB自带间接可是功能强大的JavaScript shell,这个工具对管理MongoDB实例和操作数据作用很大。

每个文档都有一个特殊的键”_id”,它在文档所处的集合中是唯一的。

MongoDB shell操作
执行shell
    #进入shell模式
> /usr/local/mongodb/bin/mongo #执行简单的计算
> x=200
200
> x/5
40 #还可充分利用JavaScript的标准库
> Math.sin(Math.PI / 2)
1
> "Hello World!".replace("World","MongoDB")
Hello MongoDB! #shell (CRUD)
#创建tets数据库
> use test;
> db
test #创建一个用户
> user={"name":"zhangsan","age":18};
{ "name" : "zhangsan", "age" : 18 }
> db.users.insert(user);
WriteResult({ "nInserted" : 1 }) #查询
#find会返回集合里的全部记录,在shell中最多显示20条数据,findOne会显示一条数据
> db.users.findOne();
{
"_id" : ObjectId("55b59ee00882afbc7416fed4"),
"name" : "zhangsan",
"age" : 18
} #更新
#改动name=zhangsan用户的年龄为20,加入个性别sex=1
> user.sex=1
1
> user.age=20
20
> db.users.update({"name":"zhangsan"},user);
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.users.findOne();
{
"_id" : ObjectId("55b59ee00882afbc7416fed4"),
"name" : "zhangsan",
"age" : 20,
"sex" : 1
} #删除
> db.users.remove({"name":"zhangsan"});
WriteResult({ "nRemoved" : 1 }) #shell帮助文档
> help
db.help() help on db methods
db.mycoll.help() help on collection methods
sh.help() sharding helpers
rs.help() replica set helpers
help admin administrative help
help connect connecting to a db help
help keys key shortcuts
help misc misc things to know
help mr mapreduce show dbs show database names
show collections show collections in current database
show users show users in current database
show profile show most recent system.profile entries with time >= 1ms
show logs show the accessible logger names
show log [name] prints out the last segment of log in memory, 'global' is default
use <db_name> set current database
db.foo.find() list objects in collection foo
db.foo.find( { a : 1 } ) list objects in foo where a == 1
it result of the last line evaluated; use to further iterate
DBQuery.shellBatchSize = x set default number of items to display on shell
exit quit the mongo shell #了解函数源码。比方update方法。输入的时候不带括号
> db.foo.update

MongoDB学习——持续更新的更多相关文章

  1. 读书笔记|Windows 调试原理学习|持续更新

    关于调试方面的学习笔记,主要来源于<软件调试>的读书笔记和梦织未来论坛的视频教程 1.调试器使用一个死循环监听调试信息. DebugActiveProcess(PID);while(TRU ...

  2. flask插件全家桶集成学习---持续更新ing

    不得不说flask的设计要比django要小巧精妙的多了,没有那么臃肿,只保留核心功能,其他的都需要自己引入,即各种各样的插件来满足我们的需求,我这里记录一下自己学习项目中用的插件使用方法和一些技巧总 ...

  3. nodejs学习[持续更新]

    1.退出node process.exit(0) 2.把API从上往下全部看一遍,先混个眼熟. 3. end

  4. nodejs 语法学习(持续更新)

    合并objects var o1 = { a: 1 }; var o2 = { b: 2 }; var o3 = { c: 3 }; var obj = Object.assign(o1, o2, o ...

  5. canvas学习持续更新

    参考:菜鸟教程,canvas教程 绘制一个简单的矩形 <body> <canvas id="myCanvas" width="200" hei ...

  6. ASP.NET MVC 5 系列 学习笔记 目录 (持续更新...)

    前言: 记得当初培训的时候,学习的还是ASP.NET,现在回想一下,图片水印.统计人数.过滤器....HttpHandler是多么的经典! 不过后来接触到了MVC,便立马爱上了它.Model-View ...

  7. 【 js 基础 】【 源码学习 】源码设计 (持续更新)

    学习源码,除了学习对一些方法的更加聪明的代码实现,同时也要学习源码的设计,把握整体的架构.(推荐对源码有一定熟悉了之后,再看这篇文章) 目录结构:第一部分:zepto 设计分析第二部分:undersc ...

  8. java 学习必备的软件,持续更新中

    小编会持续更新在学习Java过程中需要的软件以及各种文件: 话不多说,看行动! 一:JDK (1)JDK1.8(*64): 链接:https://pan.baidu.com/s/1vM0jNXn2CT ...

  9. 状压dp(状态压缩&&dp结合)学习笔记(持续更新)

    嗯,作为一只蒟蒻,今天再次学习了状压dp(学习借鉴的博客) 但是,依旧懵逼·································· 这篇学习笔记是我个人对于状压dp的理解,如果有什么不对的 ...

随机推荐

  1. WebSocket 实战(转)

    WebSocket 实战 本文介绍了 HTML5 WebSocket 的由来,运作机制及客户端和服务端的 API 实现,重点介绍服务端(基于 Tomcat7)及客户端(基于浏览器原生 HTML5 AP ...

  2. 如何让Adobe reader 记住上次pdf文档打开位置?

    菜单栏: Edit --> Preferences --> Documents --> 勾选 “Restore last view settings where reopening ...

  3. vs生成命令和属性的宏

    在vs属性页面中编辑后期生成事件... 下面是vs中宏的描述信息. http://i.cnblogs.com/EditPosts.aspx?opt=1 高级用法: 磨刀不误砍柴工——VS生成事件

  4. 分布式架构高可用架构篇_activemq高可用集群(zookeeper+leveldb)安装、配置、高可用测试

    原文:http://www.iteye.com/topic/1145651 从 ActiveMQ 5.9 开始,ActiveMQ 的集群实现方式取消了传统的Master-Slave 方式,增加了基于Z ...

  5. AtomicInteger类的简单应用

    AtomicInteger,一个提供原子操作的Integer的类.在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字.而AtomicIn ...

  6. [Android Traffic] Android网络开启、关闭整理

    转载: http://blog.csdn.net/tu_bingbing/article/details/8469871 近段时间由于要对手机网络状况进行判断.开启和关闭,从网上找了些资料,现整理如下 ...

  7. Coherence的NameService

    Coherence*Extend模式下客户端需要连接一个或多个proxy Server从而接入集群,在一些比较大型的环境中,Proxy Server往往比较多,一旦修改起来需要修改每个配置文件,在Co ...

  8. angular get/post 下载 excel

    阅读目录 get请求 post请求 最近做项目,就碰到一个导出excel表格的功能.原本是想利用web前台导出excel的,但是最后因为两点放弃了,第一点,因为中文乱码,第二点,有分页(在前台导出ex ...

  9. 安装notepad++ in ubuntu16.04

    一.安装notepad++ Ubuntu下的安装方法: sudo add-apt-repository ppa:notepadqq-team/notepadqq sudo apt-get update ...

  10. HA分布式集群配置三 spark集群配置

    (一)HA下配置spark 1,spark版本型号:spark-2.1.0-bin-hadoop2.7 2,解压,修改配置环境变量 tar -zxvf spark-2.1.0-bin-hadoop2. ...