如何我们要删除一个集合,可以采用db.test.drop()的方式,其实在这背后,这个函数运行的是drop命令。可以用runCommand达到同样的效果。

我们首先新建一个集合作为测试使用:

> use maple1

switched to db maple1

> db.maple1.insert({'name':'zhanghongfeng'})

WriteResult({ "nInserted" : 1 })

删除掉这个集合,反馈的结果中ok:1代表成功

> db.runCommand({"drop":"maple1"})

{ "ns" : "maple1.maple1", "nIndexesWas" : 1, "ok" : 1 }

如果操作失败了,会有errmsg提示失败的原因

> db.runCommand({"drop":"maple1"})

{

"ok" : 0,

"errmsg" : "ns not found",

"code" : 26,

"codeName" : "NamespaceNotFound"

}

如果想查看所有的命令在shell中运行db.listCommands()就可以得到所有的命令。下面列举下Mongodb最常用的命令。

1 buildInfo: 返回Mongodb服务器的版本号和主机的操作系统

> db.runCommand({"buildInfo":1})

{

"version" : "3.4.7",

"gitVersion" : "cf38c1b8a0a8dca4a11737581beafef4fe120bcd",

"modules" : [ ],

"allocator" : "tcmalloc",

"javascriptEngine" : "mozjs",

"sysInfo" : "deprecated",

"versionArray" : [

3,

4,

7,

0

],

"openssl" : {

"running" : "OpenSSL 1.0.2g  1 Mar 2016",

"compiled" : "OpenSSL 1.0.2g  1 Mar 2016"

},

"buildEnvironment" : {

"distmod" : "",

"distarch" : "x86_64",

"cc" : "cc: cc (Ubuntu 7.1.0-13ubuntu1) 7.1.0",

"ccflags" : "-fno-omit-frame-pointer -fno-strict-aliasing -ggdb -pthread -Wall -Wsign-compare -Wno-unknown-pragmas -Wno-nonnull-compare -Wno-error=c++1z-compat -Wno-error=noexcept-type -Wno-error=format-truncation -Wno-error=int-in-bool-context -Wno-overflow -Winvalid-pch -Werror -O2 -Wno-unused-local-typedefs -Wno-unused-function -Wno-deprecated-declarations -Wno-unused-const-variable -Wno-unused-but-set-variable -Wno-missing-braces -fstack-protector-strong -fno-builtin-memcmp",

"cxx" : "g++: g++ (Ubuntu 7.1.0-13ubuntu1) 7.1.0",

"cxxflags" : "-g -O2 -fdebug-prefix-map=/build/mongodb-5gk9fl/mongodb-3.4.7=. -fstack-protector-strong -Wformat -Werror=format-security -Woverloaded-virtual -Wno-maybe-uninitialized -std=c++11",

"linkflags" : "-Wl,-Bsymbolic-functions -Wl,-z,relro -pthread -Wl,-z,now -rdynamic -Wl,--fatal-warnings -fstack-protector-strong -fuse-ld=gold -Wl,--build-id -Wl,-z,noexecstack -Wl,--warn-execstack -Wl,-z,relro",

"target_arch" : "x86_64",

"target_os" : "linux"

},

"bits" : 64,

"debug" : false,

"maxBsonObjectSize" : 16777216,

"storageEngines" : [

"devnull",

"ephemeralForTest",

"mmapv1",

"wiredTiger"

],

"ok" : 1

}

2 collStats: 返回指定集合的统计信息,包括数据大小,已分配的存储空间和索引大小

> db.runCommand({"collStats":"maple"})

{

"ns" : "maple.maple",

"size" : 234,

"count" : 4,

"avgObjSize" : 58,

"storageSize" : 36864,

"capped" : false,

"wiredTiger" : {

"metadata" : {

"formatVersion" : 1

},

3 distinct:列出指定集合中满足查询条件的文档的指定键的所有不同值

> db.runCommand({"distinct":"maple","key":"name"})

{ "values" : [ "zhanghongfeng_maple" ], "ok" : 1 }

4 drop和dropDatabase: 删除集合的所有数据和当前数据库的所有数据

5 getlastError: 查看对本集合执行的最后一次操作的错误信息或者其他状态信息。

6 isMaster: 检查本服务器是主服务器还是从服务器

> db.runCommand({"isMaster":1})

{

"ismaster" : true,

"maxBsonObjectSize" : 16777216,

"maxMessageSizeBytes" : 48000000,

"maxWriteBatchSize" : 1000,

"localTime" : ISODate("2017-12-27T13:45:21.228Z"),

"maxWireVersion" : 5,

"minWireVersion" : 0,

"readOnly" : false,

"ok" : 1

}

7 Listcommands: 返回所有可以在服务器上运行的命令

8 listDatabases:列出服务器上所有的数据库

9 ping: 检测服务器的链接是否正常

> db.runCommand({"ping":1})

{ "ok" : 1 }

10

固定集合:

顾名思义,固定集合就是能够将集合的大小以及文档数进行固定的集合。固定集合的创建方法是用createCollection。如下所示,size代表集合的大小,max代表最大的文档个数

> db.createCollection("fixedcollection",{capped:true,size:1000,max:2})

{ "ok" : 1 }

插入2个文档

>db.fixedcollection.insert({"name":"zhanghongfeng","age":33})

> db.fixedcollection.insert({"name":"maple","age":32})

显示插入的2个文档

> db.fixedcollection.find()

{ "_id" : ObjectId("5a43a73ba889535e61dc29a8"), "name" : "zhanghongfeng", "age" : 33 }

{ "_id" : ObjectId("5a43a77ba889535e61dc29a9"), "name" : "maple", "age" : 32 }

再次插入一个文档

> db.fixedcollection.insert({"name":"zhf","age":32})

WriteResult({ "nInserted" : 1 })

通过查询可以看到插入一个文档后,最早插入的文档name:zhanghongfeng被替换掉了。这是因为我们在创建固定集合指定了最大文档个数为2个。因此新插入的文档会替换之前的文档,替换方法是替换最早建立的文档。

> db.fixedcollection.find()

{ "_id" : ObjectId("5a43a77ba889535e61dc29a9"), "name" : "maple", "age" : 32 }

{ "_id" : ObjectId("5a43a78ca889535e61dc29aa"), "name" : "zhf", "age" : 32 }

固定集合的排列方式和环形队列一样,通过指定查询的顺序来查找,$natural:-1按照文档的插入时间从晚到早的顺序,也就是从队列的末尾开始查起。$natural:1是从队列的对头开始查起

> db.fixedcollection.find().sort({"$natural":-1})

{ "_id" : ObjectId("5a43a78ca889535e61dc29aa"), "name" : "zhf", "age" : 32 }

{ "_id" : ObjectId("5a43a77ba889535e61dc29a9"), "name" : "maple", "age" : 32 }

> db.fixedcollection.find().sort({"$natural":1})

{ "_id" : ObjectId("5a43a77ba889535e61dc29a9"), "name" : "maple", "age" : 32 }

{ "_id" : ObjectId("5a43a78ca889535e61dc29aa"), "name" : "zhf", "age" : 32 }

mongodb学习之:数据库命令以及固定集合的更多相关文章

  1. MongoDB学习笔记-06 数据库命令、固定集合、GridFS、javascript脚本

    介绍MongoDB支持的一些高级功能: 数据库命令 固定大小的集合 GridFS存储大文件 MongoDB对服务端JavaScript的支持 数据库命令 命令的原理 MongoDB中的命令其实是作为一 ...

  2. MongoDB学习笔记-数据库命令

    概念 数据库命令(database command)是一种非常特殊类型的查询.文档的创建.更新.删除及查询都属于数据库命令的范畴,它还包含管理性的任务(比如关闭服务器和克隆数据库).统计数据及执行聚合 ...

  3. 【Mongodb教程 第十七课 】MongoDB常用命令 数据库命令 集合操作命令

    (1)数据库命令 a)添加用户 db.addUser(‘name’,’pwd’) b)删除用户 db.removeUser(‘name’) c)用户验证 db.auth(‘name’,’pwd’) d ...

  4. MongoDB学习笔记(二)--Capped集合 && GridFS存储文件

    Capped集合                                                            Capped集合的大小是固定的,如果空间都被用完了,新添加的对象 ...

  5. 【Mongodb教程 第十八课 】MongoDB常用命令 数据库命令 集合操作命令

    面向文档的 NoSQL 数据库主要解决的问题不是高性能的并发读写,而是保证海量数据存储的同时,具有良好的查询性能.  条件操作符 <, <=, >, >=  这个操作符就不用多 ...

  6. MongoDB学习笔记(数据操作)

    1.  批量插入:     以数组的方式一次插入多个文档可以在单次TCP请求中完成,避免了多次请求中的额外开销.就数据传输量而言,批量插入的数据中仅包含一份消息头,而多次单条插入则会在每次插入数据时封 ...

  7. mongodb学习比较(数据操作篇)

    1.  批量插入:     以数组的方式一次插入多个文档可以在单次TCP请求中完成,避免了多次请求中的额外开销.就数据传输量而言,批量插入的数据中仅包含一份消息头,而多次单条插入则会在每次插入数据时封 ...

  8. MongoDB的分片数据库命令总结

    sh._adminCommand 在admin数据库运行database command ,就像db.runCommand() ,不过可以保证只在 mongos 上运行. sh._checkFullN ...

  9. 初步学习大数据——设置虚拟机固定ip地址

    1.打开本机的网络连接 2.右键以太网,打开属性. 3.右键VMnet8,打开属性.最多不能超过255,最少不能小于0.    0~255之间. 4.找到你要设置固定IP地址的虚拟机 ,选择上方的编辑 ...

随机推荐

  1. centos 7安装postgresql10.3

    最新版本安装请移步:阿里云服务器 centos 7 安装postgresql 11 一.Postgresql简介 官方网站:https://www.postgresql.org/ 简介参考zhihu文 ...

  2. AC日记——乘积最大 洛谷 P1018

    题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...

  3. Windows Builder(图形化界面的利器)For Eclipse 3.7

    工欲善其事,必先利其器——孔子(春秋)<论语·卫灵公> 今天闲逛论坛的时候,发现了Eclipse 的很好的插件,是关于做图形界面的. 如果想做桌面应用软件,交互界面有点复杂的时候,自己手动 ...

  4. 51nod 1092 回文字符串【LCS】

    1092 回文字符串 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题 收藏 关注 回文串是指aba.abba.cccbccc.aaaa这种左右对称的字符串.每个字符 ...

  5. Java并发容器,底层原理深入分析

    ConcurrentHashMap ConcurrentHashMap底层具体实现 JDK 1.7底层实现 将数据分为一段一段的存储,然后给每一段数据配一把锁, 当一个线程占用锁访问其中一个段数据时, ...

  6. 转:关于使用ImageMagick和Tesseract进行简单数字图像识别

    据说Tesseract可是世界排名第三的OCR神器,2010年又更新了3.0版本.Tesseract原先是HP写的,现在Open Source了. 下面介绍怎么用Tesseract配合ImageMag ...

  7. spring事务再次理解

    2.2.3 只读 事务的第三个特性是它是否为只读事务.如果事务只对后端的数据库进行该操作,数据库可以利用事务的只读特性来进行一些特定的优化.通过将事务设置为只读,你就可以给数据库一个机会,让它应用它认 ...

  8. 老毛桃winpe优盘启动系统个性修改全攻略.(全)

    博主从05年开始接触计算机,不能说是高手也算个老菜了,当时装系统还是用蕃茄花园的光盘安装系统,后来在学校管理机房,哪台电脑坏了就硬盘对拷. 时到今日,重启系统的方法五花八门,其中使用最广的莫过于PE优 ...

  9. requests(爬虫常用)库的使用

    Requests库的使用 基于urllib改写的库 示例: import requests response=requests.get('http://www.baidu.com')#get请求 pr ...

  10. basePath 方便

    String path = request.getContextPath()+"/";String basePath = request.getScheme() + ": ...