数组查询

数组查询

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
-9
 MongoDB 进程,如需正常安全的退出,向进程发送 SIGINT 或 SIGTERM 信号,如:

$ 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 经常使用的操作的更多相关文章

  1. 【mongodb系统学习之八】mongodb shell常用操作

    八.mongodb  shell常用基础操作(每个语句后可以加分号,也可以不加,看情况定(有的工具中可以不加),最好是加): 1).进入shell操作界面:mongo,上边已有演示: 2).查看当前使 ...

  2. MongoDB Shell 经常使用操作

    数组查询 数组查询 MongoDB 中有子文档的概念.一个文档中能方便的嵌入子文档,这与关系性数据库有着明显的不同,在查询时,语法有一些注意点. 样例代码,假如我们的一个集合(tests)中存在标签键 ...

  3. MongoDB 基础 -安全性-(权限操作)

    和其他所有数据库一样,权限的管理都差不多一样.mongodb存储所有的用户信息在admin 数据库的集合system.users中,保存用户名.密码和数据库信息.mongodb默认不启用授权认证,只要 ...

  4. MongoDB入门三:MongoDB shell

    MongoDB shell MongDB shell是一个功能完备的Javascript解释器,可以运行Javascript程序.也可以用于连接MongoDB服务器,执行脚本,对数据库进行操作.类似于 ...

  5. MongoDB:Replica Set 之操作日志 Oplog

    转载地址:http://francs3.blog.163.com/blog/static/4057672720121133328120/ 之前的blog  学习了 MongoDB 主从搭建,以及节点管 ...

  6. [转载]MongoDB学习(三):MongoDB Shell的使用

    MongoDB shell MongoDB自带简洁但功能强大的JavaScript shell.JavaScript shell键入一个变量会将变量的值转换为字符串打印到控制台上. 下面介绍基本的操作 ...

  7. MongoDB副本集的常用操作及原理

    本文是对MongoDB副本集常用操作的一个汇总,同时也穿插着介绍了操作背后的原理及注意点. 结合之前的文章:MongoDB副本集的搭建,大家可以在较短的时间内熟悉MongoDB的搭建和管理. 下面的操 ...

  8. 【mongodb系统学习之三】进入mongodb shell

    三. 进入mongodb shell(数据库操作界面) : 1).在mongodb的bin目录下输入./mongo,默认连接test数据库,连接成功会显示数据库版本和当前连接的数据库名,如图: 2). ...

  9. MongoDB shell 介绍

    MongoDB shell 介绍 MongoDB自带javascript shell, 可在shell中使用命令行与MongoDB实列交互.shell可以执行管理操作,检查运行实列等等操作. 一:如何 ...

随机推荐

  1. ios开发多线程一:了解-NSOperation的基本使用

    #import "ViewController.h" @interface ViewController () @end @implementation ViewControlle ...

  2. iOS开发Quartz2D十二:手势解锁实例

    一:效果如图: 二:代码: #import "ClockView.h" @interface ClockView() /** 存放的都是当前选中的按钮 */ @property ( ...

  3. OpenStack 之 Nova Compute 的代码结构图

    nova-compute 的代码结构图 如上图所看到的, 类图中最重要的三个Category Manager: 核心的业务类.提供实际的业务操作.比如启动虚拟机等等. Service: 每一个serv ...

  4. windows 下安装git

    Git是当今最流行的版本控制软件,它包含了许多高级工具,这里小编就讲一下Git的安装. 首先如下图:(点击next) 第二步:文件位置存储,可根据自己盘的情况安装 第三步:安装配置文件,自己需要的都选 ...

  5. 用Ajax图片上传、预览、修改图片

    首选图片的上传和下载并不是很难,但要注意细节. 一,给出前端图片上传的html代码 1.图片上传的控件 <img src="/${res}/images/default.png&quo ...

  6. 一起学Python:tcp服务器

    tcp服务器 生活中的电话机 如果想让别人能更够打通咱们的电话获取相应服务的话,需要做以下几件事情: 买个手机 插上手机卡 设计手机为正常接听状态(即能够响铃) 静静的等着别人拨打 tcp服务器 如同 ...

  7. [NPM] Use package.json variables in npm scripts

    In this lesson we will show that you can leverage values that you already have provided in your pack ...

  8. iOS:通过URL构件UIImage

    非常多时候我们仅仅能得到一个URL,然后须要构建一个UIImage. 通常情况下,我们一般都是通过SDWebImage来直接构建UIImageVIew的image,怎样用URL直接构建UIImage呢 ...

  9. 热烈庆祝UE4完全免费Free---GitHub上源码的关联方法

    声明:所有权利保留. 转载请说明出处:http://blog.csdn.net/cartzhang/article/details/44040317 IF YOU LOVE SOMETHING, SE ...

  10. git自己操作命令组集合

    git自己操作命令组集合 一.总结 一句话总结: 1.官方有非常详细的中文文档资料,任何组件或者插件记得看有没有文档资料,这个用起来快,配合百度. 2.git clone命令是直接把git仓库上面的代 ...