MongoDB Shell 经常使用操作
数组查询
数组查询
MongoDB 中有子文档的概念。一个文档中能方便的嵌入子文档,这与关系性数据库有着明显的不同,在查询时,语法有一些注意点。
样例代码,假如我们的一个集合(tests)中存在标签键。有例如以下模式:
tags: [ObjectId]
查询含有某个标签 ID 的文档
db.tests.find({tags: tagId});
我如今有一组标签 tagIds,即是数组,须要查询含有该数组中任一元素的文档。此时须要用到 $in 操作符
db.tests.find({tags: {$in: tagIds}});
如需唯一匹配该数组,与通常查询无异
db.tests.find({tags: tagIds});
如不考虑顺序关系影响,即同一时候含有 tagIds 中的每一个元素,用 $all
db.tests.find({tags:
{$all: tagIds}});
MongoDB数据导出及导入
我眼下用到的各自是 mongodump 和 mongorestore。他们语法挺相似。
导出
mongodump --host localhost:27017 /data/backup/csser.com/csser.3-9/
表示将当前数据库导出到 csser.3-9 文件夹中去,导入用 mongorestore 就可以恢复。
导入
mongorestore --host localhost:27017 /data/backup/csser.com/csser.3-9/
表示将 csser.3-9
文件夹下的数据导入到 MongoDB 中。
安全停止并退出MongoDB
安全停止并退出 MongoDB
不管怎样都要避免直接 kill
MongoDB 进程。如需正常安全的退出,向进程发送 SIGINT 或 SIGTERM 信号,如:
-9
$ sudo kill -2 pid // SIGINT
// 或
$ sudo kill pid // SIGTERM
查看集合占用空间
查看集合占用空间
> db.sessions.dataSize()
22658540
监控和释放MongoDB占用的内存
监控和释放 MongoDB 占用的内存
查看内存使用情况:
PRIMARY> use csser
switched to db csser
PRIMARY> db.serverStatus().mem
{
"bits" : 64,
"resident" : 82,
"virtual" : 5366,
"supported" : true,
"mapped" : 2463,
"mappedWithJournal" : 4926
}
释放内存:
db.runCommand({closeAllDatabases:1})
查看MongoDB连接数
查看 MongoDB 连接数
> db.serverStatus().connections
{ "current" : 10, "available" : 809 }
进入Shell
进入 Shell
通过 mongo 命令连接数据库后,会自己主动进入 MongoDB Shell,默认连接的是 test 数据库。进行例如以下操作了解 Shell 基本指令:
> help
db.help() #查看 db 方法
db.mycoll.help() #查看集合方法
rs.help() #查看 replica set 方法
help admin #管理员帮助
help connect #连接数据库帮助
help keys #快捷键帮助
help misc #了解 misc
help mr #mapreduce show dbs #打印本server存在的数据库名称列表
show collections #打印当前数据库的集合列表
show users #打印当前数据库的用户
show profile #打印 1s 内的 system.profile
show logs #打印 logger 名称
show log [name] #打印内存中最新的一条日志记录,[name] 默觉得 'global'
use <db_name> #切换数据库
db.foo.find() #列出集合 foo 中的对象列表
db.foo.find( { a : 1 } ) #列出集合 foo 中满足条件 a== 1 的对象列表
it #查看 find 返回列表的其余部分
DBQuery.shellBatchSize = x #设置 shell 默认显示的项的个数
exit #退出 mongodb shell
MongoDB shell 内嵌了 Javascript 解析器,所以能够在当中书写 Javascript 代码。
连接数据库
连接数据库
mongo [options] [db address] [文件名称 (以.js结尾)]
db address 能够仅仅指定数据库名(比方:csser),此时连接本地数据库csser。
也能够这样:192.169.0.5:27018/csser,表明连接192.169.0.5server27018port的csser数据库,port号能够省略。默觉得27017。
假设指定文件名称。在不指定 --shell 參数的情况下,进程在运行完这些js文件之后会自己主动退出。文件名称必须以.js结尾。
查看 MongoDB 版本号:
mongo --version
在执行 mongo 命令时不自己主动连接数据库:
mongo --nodb
MongoDB Shell 经常使用操作的更多相关文章
- 【mongodb系统学习之八】mongodb shell常用操作
八.mongodb shell常用基础操作(每个语句后可以加分号,也可以不加,看情况定(有的工具中可以不加),最好是加): 1).进入shell操作界面:mongo,上边已有演示: 2).查看当前使 ...
- 【mongodb系统学习之三】进入mongodb shell
三. 进入mongodb shell(数据库操作界面) : 1).在mongodb的bin目录下输入./mongo,默认连接test数据库,连接成功会显示数据库版本和当前连接的数据库名,如图: 2). ...
- MongoDB Shell 经常使用的操作
数组查询 数组查询 MongoDB 中有子文档的概念,一个文档中能方便的嵌入子文档,这与关系性数据库有着明显的不同.在查询时,语法有一些注意点. 样例代码,假如我们的一个集合(tests)中存在标签键 ...
- MongoDB入门三:MongoDB shell
MongoDB shell MongDB shell是一个功能完备的Javascript解释器,可以运行Javascript程序.也可以用于连接MongoDB服务器,执行脚本,对数据库进行操作.类似于 ...
- [转载]MongoDB学习(三):MongoDB Shell的使用
MongoDB shell MongoDB自带简洁但功能强大的JavaScript shell.JavaScript shell键入一个变量会将变量的值转换为字符串打印到控制台上. 下面介绍基本的操作 ...
- MongoDB shell 介绍
MongoDB shell 介绍 MongoDB自带javascript shell, 可在shell中使用命令行与MongoDB实列交互.shell可以执行管理操作,检查运行实列等等操作. 一:如何 ...
- mongodb shell和Node.js driver使用基础
开始: Mongo Shell 安装后,输入mongo进入控制台: //所有帮助 > help //数据库的方法 > db.help() > db.stats() //当前数据库的状 ...
- MongoDB中的聚合操作
根据MongoDB的文档描述,在MongoDB的聚合操作中,有以下五个聚合命令. 其中,count.distinct和group会提供很基本的功能,至于其他的高级聚合功能(sum.average.ma ...
- MongoDB安装、CURD操作、使用场景分析总结(1)
NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL".非关系型的数据存储 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 ...
随机推荐
- php高并发秒杀解决方案
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/super_runman/article/details/53037151 在秒杀.抢火车票等地方,我 ...
- Mongodb总结1-启动和Shell脚本
2013年,还在秒针,当时听说了Mongodb,就学习了下,搞了下HelloWorld.主要是熟悉Mongodb的启动.命令行的Shell脚本.Java访问的CRUD. 今天,由于需要,再次回顾和进一 ...
- Qt产生随机数(两种方法)
第一种方法 #include <QTime> QTime time; time= QTime::currentTime(); qsrand(time.msec()+time.second( ...
- Altium Designer如何改两个原件之间的安全距离
在pcb中按 D R 一个事垂直距离, 另一个是水平距离.
- StackExchange.Redis 官方文档(六) PipelinesMultiplexers
原文:StackExchange.Redis 官方文档(六) PipelinesMultiplexers 流水线和复用 糟糕的时间浪费.现代的计算机以惊人的速度产生大量的数据,而且高速网络通道(通常在 ...
- promis:异步编程
promise对象用于延迟计算和异步计算:一个promise对象代表着一个还未完成,但预期将来完成的操作 Image.png Image.png 打印结果如下: <!DOCTYPE html&g ...
- wepy小程序实现列表分页上拉加载(1)
使用wepy开发微信小程序商城第一篇:项目初始化 使用wepy开发微信小程序商城第二篇:路由配置和页面结构 列表页效果图: 1.新建列表页 (1)在pages里面新建一个list.wpy文件 初始代码 ...
- 6.4 Android硬件访问服务编写HAL代码
JNI向上提供本地函数,向下加载HAL文件,并调用HAL的函数: HAL负责访问驱动程序执行硬件操作 JNI和HAL都是用c语言或者C++语言编写的,JNI加载HAL的实质就是使用dlopen加载动态 ...
- BUFSIZ
转http://www.judymax.com/archives/262 今天在看示例程序时冒出来一句args = emalloc(BUFSIZ); BUFSIZ是什么意思,查了一下才明白. 这是st ...
- WM_CAP_DRIVER_CONNECT
WM_CAP_DRIVER_CONNECT //ActiveX ---->OnCreate m_pit.Create(IDD_CAM_DIALOG,this); CRect rc; this ...