一、索引

1.插入10W条数据 文档内容为:{name:zs-i,age:1}

2016-06-07T14:35:57.041+0800 I CONTROL [initandlisten]

> for(var i=0;i<100000;i++){

... db.person.insert({name:"zs"+i,age:i})

... }

WriteResult({ "nInserted" : 1 })

2.在属性name上创建索引

> db.person.ensureIndex({name:1})

{

"createdCollectionAutomatically" : false,

"numIndexesBefore" : 1,

"numIndexesAfter" : 2,

"ok" : 1

}

3.查看执行计划,观察使用索引和不使用索引的区别

建立索引前

> db.person.find({name:"zs"+10000}).explain()

{

"cursor" : "BasicCursor",

"isMultiKey" : false,

"n" : 1,

"nscannedObjects" : 100000,

"nscanned" : 100000,

"nscannedObjectsAllPlans" : 100000,

"nscannedAllPlans" : 100000,

"scanAndOrder" : false,

"indexOnly" : false,

"nYields" : 781,

"nChunkSkips" : 0,

"millis" : 30,

"server" : "weekend01:27017",

"filterSet" : false

}

建索引后

> db.person.find({name:"zs"+10000}).explain()

{

"cursor" : "BtreeCursor name_1",

"isMultiKey" : false,

"n" : 1,

"nscannedObjects" : 1,

"nscanned" : 1,

"nscannedObjectsAllPlans" : 1,

"nscannedAllPlans" : 1,

"scanAndOrder" : false,

"indexOnly" : false,

"nYields" : 0,

"nChunkSkips" : 0,

"millis" : 0,

"indexBounds" : {

"name" : [

[

"zs10000",

"zs10000"

]

]

},

"server" : "weekend01:27017",

"filterSet" : false

}

> db.person.find({name:"zs"+10000}).hint({name:1}).explain()

{

"cursor" : "BtreeCursor name_1",

"isMultiKey" : false,

"n" : 1,

"nscannedObjects" : 1,

"nscanned" : 1,

"nscannedObjectsAllPlans" : 1,

"nscannedAllPlans" : 1,

"scanAndOrder" : false,

"indexOnly" : false,

"nYields" : 0,

"nChunkSkips" : 0,

"millis" : 0,

"indexBounds" : {

"name" : [

[

"zs10000",

"zs10000"

]

]

},

"server" : "weekend01:27017",

"filterSet" : false

}

二、备份与恢复

1.中断备份与恢复

a.备份数据库test中的student

[root@weekend01 ~]# mongoexport -d test -c student -o studnet.json

connected to: 127.0.0.1

exported 0 records

b.删除数据库test中的student

> db.student.drop()

true

c.恢复数据库test中的student

导入其他数据

[root@weekend01 ~]# mongoimport --db test --collection student --file studnet.json

connected to: 127.0.0.1

2016-06-07T18:02:18.612+0800 check 0 0

2016-06-07T18:02:18.612+0800 imported 0 objects

2.运行时备份与恢复、

a.备份数据库test

[root@weekend01 ~]# mongodump --host 127.0.0.1:27017 -d test -o /tmp

connected to: 127.0.0.1:27017

2016-06-07T18:04:27.161+0800 DATABASE: test to /tmp/test

2016-06-07T18:04:27.167+0800 test.system.indexes to /tmp/test/system.indexes.bson

2016-06-07T18:04:27.167+0800 2 documents

2016-06-07T18:04:27.167+0800 test.person to /tmp/test/person.bson

2016-06-07T18:04:27.482+0800 100000 documents

2016-06-07T18:04:27.482+0800 Metadata for test.person to /tmp/test/person.metadata.json

b.删除数据库test

> db.dropDatabase()

{ "dropped" : "test", "ok" : 1 }

c.恢复数据库test

[root@weekend01 ~]# mongorestore --host 127.0.0.1:27017 -d test -directoryperdb /tmp/test/

connected to: 127.0.0.1:27017

2016-06-07T18:06:22.060+0800 /tmp/test/person.bson

2016-06-07T18:06:22.060+0800 going into namespace [test.person]

100000 objects found

2016-06-07T18:06:23.253+0800 Creating index: { key: { _id: 1 }, name: "_id_", ns: "test.person" }

2016-06-07T18:06:23.297+0800 Creating index: { key: { name: 1 }, name: "name_1", ns: "test.person" }

主要算法及程序清单

a.插入10W条数据

for(var i=0;i<100000;i++){

db.person.insert({name:"zs"+i,age:i})

}

b.查询name为zs10000的数据

db.person.find({name:"zs"+10000}).explain() --看效果,此时没建name索引

c.建立索引

db.person.ensureIndex({name:1})

d.查询name为zs10000的数据

db.person.find({name:"zs"+10000}).explain()

db.person.find({name:"zs"+10000}).hint({name:1}).explain() --看效果,此时已建name索引

1.中断操作 -- 像冷备

a.把数据库test中的student导出 --备份

mongoexport -d test -c student -o d:/student.json

mongoexport --db test --collection student --out /root/student1.json

b.删除test数据库中的student

db.student.drop()

c.导入数据(中断其他操作) --恢复

mongoimport --db test --collection student --file /root/student.json

mongoimport -d test -c student --file d:/student.json

2.运行时备份 --像热备 整库备份

a.导出数据库

mongodump --host 127.0.0.1:27017 -d test -o /root

b.删除整个数据库

db.dropDatabase()

c.运行时恢复

mongorestore --host 127.0.0.1:27017 -d test -directoryperdb /tmp/test

疑难小结

本次实验重在考察对mongoDB的操作,类似上个实验,本次实验中难题没有,都是些基本的操作,只要在明白其理论基础上加上多敲多练多想就会有很大收获。看着再简单,不动手永远不知道自己会碰到什么状况,所以还是要多动手练习。

MongoDB管理练习的更多相关文章

  1. MongoDB管理工具的插件系统

    MongoDB管理工具  MongoCola的开发已经进入第三个年头了. 官方对于C#驱动的投入不够导致了很多东西都必须自己实现,但是不管怎么样,工具现在已经很强大了. 最近准备着手插件系统的开发,简 ...

  2. MongoDB管理与开发精要 书摘

    摘自:<MongoDB管理与开发精要>         性能优化 创建索引 限定返回结果条数 只查询使用到的字段,而不查询所有字段 采用capped collection 采用Server ...

  3. mongodb管理工具rockmongo

    mongodb的图像管理工具非常之多,我用的是rockmongo. RockMongo 是一个PHP5写的MongoDB管理工具. 主要特征: 使用宽松的New BSD License协议 速度快,安 ...

  4. Nodejs mongodb 管理组件adminmongodb

    强大的 nodejs的mongodb管理工具,强大到即下即用: 安装需求: 1.git命令获取组件包,git clone https://github.com/mrvautin/adminMongo. ...

  5. 详解MongoDB管理命令

    MongoDB是一个NoSQL数据库系统:一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表:而每个集合中可以存储一组由列标识的记录,列是可以自由定义的,非常灵活,由一 ...

  6. MongoDB管理

    前几篇文章都是从开发和使用的角度了解了MongoDB的各个知识点,这篇文章将从MongoDB管理的角度入手,了解MongoDB管理所要了解的基本知识. 数据库命令 在前面几篇文章中,已经接触了一些数据 ...

  7. MongoDB.WebIDE:升级版的Mongodb管理工具

    很早以前收藏了一片文章:<强大的MongoDB数据库管理工具>.最近刚好要做一些MongoDB方面的工作,于是翻出来温习了一下,用起来也确实挺方便.不过在使用过程中出现了一些个问题,加上更 ...

  8. mongodb管理与安全认证

    mongodb数据管理 数据的导出.数据导入数据导出 mongoexport [使用mongoexport -h查看参数] 数据导入 mongoimport [使用mongoimport -h查看参数 ...

  9. MongoDB管理与开发实战详解文摘

    第1篇 基础篇 第1章 MongoDB简介 关系型数据库面临的问题:数据库并发负载高,海量数据存储与访问,数据库数据越来越大,事务管理的负担,关系型数据库读.写实时性的忽略,多表关联查询被弱化 第2章 ...

  10. mongodb进阶三之mongodb管理

    http://blog.csdn.net/stronglyh/article/details/46827141 平时的开发环境win比較多啊,但生产环境要放到unix环境上 一:命令 安装就不少了,网 ...

随机推荐

  1. spring的依赖注入(DI)、控制反转(IOC)和面向切面(AOP)

    在spring的配置文件增加 <context:component-scan base-package="com.jmu.ccjoin.service"/> <c ...

  2. 关于谷歌浏览器默认字体12px的解决方案

    1. * Chrome 中文界面下默认会将小于 12px 的文本强制按照 12px 显示, 可通过加入 CSS 属性 -webkit-text-size-adjust: none; 解决. 超链接访问 ...

  3. java如何判断字符串是否为空(小知识)

    方法一: 最多人使用的一个方法, 直观, 方便, 但效率很低: if(s == null ||"".equals(s));方法二: 比较字符串长度, 效率高, 是我知道的最好一个方 ...

  4. javascript 树形菜单

    1. [代码][JavaScript]代码     var ME={ini:{i:true,d:{},d1:{},h:0,h1:0,h2:0},html:function(da,f){var s='& ...

  5. jsp项目上传到服务器

    我们通过Myeclipse完成一个Java web项目时只能通过本地访问来查看,但是我们想把它上传到服务器上使用外网访问应该怎么做呢,首先肯定是要有一台服务器 个人调试项目试手的话我建议去买阿里云的云 ...

  6. [SoapUI] Read data from response , use it to update parameter

    import com.eviware.soapui.support.GroovyUtils def groovyUtils = new GroovyUtils( context ) def holde ...

  7. 「咕咕网校 - 基础省选」树上问题的进阶 by Drench

    一定要在noip之前把自己花钱买的Luogu网课梳理完!QAQ 树上前缀和: 对于有根树,在每个点记录 val (点权) 和 sum(到根的点权之和) 当然记录的值因题而异(但是既然叫树上前缀和当然就 ...

  8. CoreOS,CoreOS,一款 Linux 容器发行版

    CoreOS,一款最新的 Linux 发行版本,支持自动升级内核软件,提供各集群间配置的完全控制. 关于使用哪个版本的 Linux 服务器系统的争论,常常是以这样的话题开始的: 你是喜欢基于 Red ...

  9. JAVA RTTI

    基础类可接收我们发给派生类的任何消息,因为两者拥有完全一致的接口.我们要做的全部事情就是从派生上溯造型,而且永远不需要回过头来检查对象的准确类型是什么.所有细节都已通过多态性获得了完美的控制. 但经过 ...

  10. vue随笔2

    vue2.0中移除.sync修饰符 .sync可是实现props的双向数据绑定,但是会破坏[单向数据流]的假设.这样的话在改变子组件时,父组件同时也改变,你完全不知道它是何时悄悄地改变了父组件的状态. ...