开启查询:

db.getMongo().setSlaveOk()

查版本:

db.servion();

db.serverBuildInfo();

db.serverStatus().storageEngine; //查询存储引擎类型

db.collection_name.totalIndexSize(); 查询该集合索引大小

db.collection_name.stats(); 查询集合的统计信息

1.查user集合中所有记录

db.user.find();

2.通过指定条件查

db.user.find({"uname":"zhangsan"});--查uname为zhangsan的记录

db.user.find({condition}) //查满足条件的记录数

3.条件操作符

>大于-----$gt

<小于-----$lt

>=大于等于-$gte

<=小于等于-$lte

例:

db.user.find({age:{$gt:22}});--查user集合中age大于22的数据

db.user.find({age:{$lt:22}});--查user集合中age小于22的数据

db.user.find({age:{$gte:22}});--查user集合中age大于等于22的数据

db.user.find({age:{$gt:17,$lt:24}});--查user集合中age大于17,小于24的数据

$ne 不等于

例:db.things.find( { x : { $ne : 3 } } ) //查x不等于3的记录

$nin 不属于

db.things.find({j:{$nin: [2,4,6]}}) //j不等于2,4,6中的任何一个 或者j不存在的记录

$in 属于

db.things.find({j:{$in:[2,4,6]}}) //条件相当于 j等于【2,4,6】中的任何一个 in只能处理一个key对应多个value的情况

$or 或者 --or用于处理 多个键中查询任意给定的值

db.things.find("$or":[{"j":{"$in":[2,4,6]}}, {"x":"zz"},]); //查j为2,4,6 或者 x为zz的记录

$size

$mod 取模运算

例:db.things.find( { a : { $mod : [ 10 , 1 ] } } ) //等同于 a%10==1; 即a除以10余1的记录

正则表达式查询

db.things.find(a:/^java/) // where a like ”java%“

db.things.find(a:/[7-9]/) // 当name为字符串 且包含7,8,9中任意一个数字 则会查询命中

5.条件操作符 $type

$type操作符是基于BSON类型来检索集合中匹配的结果

例:

db.user.find({name:{$type:2}});--查user集合中所有name字段是字符类型的数据

db.user.find({age:{$type:16}});--查user集合中所有age字段是整型的数据

6.获取指定数量的数据记录

limit()与skip()方法

格式:db.collection_name.find().limit(number)----查前number条记录

db.collection_name.find().limit(number).skip(number2);--查前number条记录,跳过前number2条

7.比较两个字段

{$where:"this.A!=this.B"}

{$where:"this.A==this.B"}

8.去重

db.collection_name.distinct("filed_name");

9.查空值

db.collection_name.find({age:null}) //可以查出age值为空和age字段不存在的记录

10.取ObjectId时间戳

ObjectId('3f56gsdse.....').getTimestamp();

-----------------------------------数组查----------------------------------------------

数据:

{ "_id" : 1, "fruit" : [ "apple", "banana", "peach" ] }

{ "_id" : 2, "fruit" : [ "apple", "orange", "peach" ] }

{ "_id" : 3, "fruit" : [ "orange", "banana", "peach" ] }

1.$all 全部属于

db.things.find({a:{$all:[2,3]}}); //与$in类似,但必须是[]的值全部都存在

2.$elemMatch 至少有一个

例如:{ _id: 1, results: [ 82, 85, 88 ] }

{ _id: 2, results: [ 75, 88, 89 ] }

执行:db.scores.find( { results: { $elemMatch: { $gte: 80, $lt: 85 } } }) //查results集合中至少有个数是 大于等于80并小于85 的记录

结果:{ "_id" : 1, "results" : [ 82, 85, 88 ] }

3.$size 按照数组长度查询(元素个数)

db.collection_name.find({arryField:{$size:3}}) //查arryField数组长度为3的数据

4.输入一个元素查询

db.collection_name.find({fruit:'apple'})

结果: { "_id" : 1, "fruit" : [ "apple", "banana", "peach" ] }

{ "_id" : 2, "fruit" : [ "apple", "orange", "peach" ] }

5.按照数组中指定位置的元素进行查询,注意数组下标的起始编号是0。

db.collection_name.find("fruit.1":'orange');

结果:{ "_id" : 2, "fruit" : [ "apple", "orange", "peach" ] }

管理

mongodb任务操作

currnetOp用于查询当前数据库上此时此刻的操作语句信息,包括CRUD等操作.

1.当查询超过1000秒的,停止:
db.currentOp().inprog.forEach(function(item){if(item.secs_running > 1000 )db.killOp(item.opid)}) 2.停止某个数据源的查询:
db.currentOp().inprog.forEach(function(item){if(item.ns == "cswuyg.cswuyg")db.killOp(item.opid)}) 3.把所有在等待锁的操作显示出来:
db.currentOp().inprog.forEach(function(item){if(item.waitingForLock)print(JSON.stringify(item))}) 4.把处于等待中的分片显示出来:
db.currentOp().inprog.forEach(function(item){if(item.waitingForLock){print(item.opid.substr(0,9));print(item.op);}}) 5.查找所有的查询任务:
db.currentOp().inprog.forEach(function(item){if(item.op=="query"){print(item.opid);}}) 6.查找所有的非查询任务:
db.currentOp().inprog.forEach(function(item){if(item.op!="query"){print(item.opid);}}) 7.查找所有的操作:
db.currentOp().inprog.forEach(function(item){print(item.op, item.opid);}); 查DB中collection的数量
db.system.namespaces.count()

MongoDB系列----查的更多相关文章

  1. MongoDB系列(二):C#应用

    前言 上一篇文章<MongoDB系列(一):简介及安装>已经介绍了MongoDB以及其在window环境下的安装,这篇文章主要讲讲如何用C#来与MongoDB进行通讯.再次强调一下,我使用 ...

  2. MongoDB系列之二(主动复制)

    目前我正在进行MongoDB的双机热备方面相关的工作.根据我目前看到的MongoDB方面的材料,MongoDB的实际部署有三种方式,分别是“主动复制”,“副本集”以及“分片副本集”. 首先我们从最简单 ...

  3. mongodb系列之---副本集配置与说明

    在配置副本集之前,我们先来了解一些关于副本集的知识. 1,副本集的原理 副本集的原理与主从很相似,唯一不同的是,在主节点出现故障的时候,主从配置的从服务器不会自动的变为主服务器,而是要通过手动修改配置 ...

  4. MongoDB 系列文章

    MongoDB 系列文章 本文的内容是基于 MongoDB 4.0 的. 参考于 MongoDB 4.0 官方文档. 搭建 MongoDB从搭建到优化 MongoDB-副本集搭建与管理 管理 Mong ...

  5. mongoDB系列之(二):mongoDB 副本集

    1. 什么是副本集 副本集就是mongoDB副本所组成的一个集群. 同期原理是,写操作发生在主库,从库同步主库的OpLog日志. 集群中没有特定的主库,主库是选举产生,如果主库down了,会再选举出一 ...

  6. mongodb系列之-治理mongodb->db.currentOp()

    mongodb系列之-管理mongodb->db.currentOp() 管理mongodb->db.currentOp(), 绝对是原创... 今天公司的dba在内部分享了针对mysql ...

  7. 14.MongoDB系列之配置分片

    1. 启动服务器 1.1 启动配置服务器 配置服务器是集群的大脑,保存着关于每个服务器包含哪些数据的所有元数据,因此,必须首先创建配置服务器. 由于资源限制,在同一机器上启动三个进程 # mkdir ...

  8. MongoDB系列(三):增删改查(CURD)

    上篇讲了MongoDB的基础知识,大家应该对MongoDB有所了解了,当然真正用的还是curd操作,本篇为大家讲解MongoDB的curd操作. 1.数据库操作 #.增 use config #如果数 ...

  9. MongoDB系列---用户及权限管理02

    MongoDB-——Privilege 学习大纲: 1.用户权限管理 2.用户操作 知识回顾:  本系列上一篇博文我们讲述了如何搭建环境以及配置我们的MongoDB,通过搭建环境后我们又学习了如何通过 ...

随机推荐

  1. MyString

    [摘自C++程序设计语言] MyString.h #include <cstring> #include <iostream> #include <stdexcept&g ...

  2. net core体系-web应用程序-4asp.net core2.0 项目实战(1)-10项目各种全局帮助类

    本文目录 1.  前沿2.CacheHelper基于Microsoft.Extensions.Caching.Memory封装3.XmlHelper快速操作xml文档4.SerializationHe ...

  3. 一次国际化记录以及平铺JSON数据

    ​ 写这个方法的原因是因为我们需要改版国际化,因为相同的项目有其他分支做过国际化,但是主版本没有进行过国际化,目前需要修改主版本的国际化,但是因为国际化的方式做了结构上的调整所以写了这个工具方法方便去 ...

  4. Windows Vue 安装

    https://nodejs.org/dist/v6.9.5/node-v6.9.5-x64.msi 新建文件夹 node_global新建文件夹 node_cachenpm config set p ...

  5. HBuilder 的使用

    创建一个nui项目 打开index.html才能运行 查看夜神模拟器 创建App标题:mhe :在body中输入mhe让后回车,如果右侧不显示,Ctrl+s保存一下 创建标题:mhe 创建九宫格:mb ...

  6. vue PC端项目中解决userinfo问题

    在vue2 中用脚手架建立的项目,后端提供接口获取数据.在公司做第一个项目的时候不清楚公司里的对接流程,结果后续代码被一个接口整的乱七八糟,这个接口是获取用户信息的接口——'usre/info'. 如 ...

  7. debian包的补丁管理工具:quilt

    最近项目是改pam软件包,给里面添加一些功能.其中遇到了更改后,代码提交方式的问题.这里转载的文章介绍了使用quilt管理补丁的详细方法: 转自:http://blog.csdn.net/fmddlm ...

  8. 剑指offer——python【第59题】按之子形顺序打印二叉树

    题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 解题思路 这道题其实是分层打印二叉树的进阶版 ...

  9. PDF的水印怎么去掉

    很多朋友私下都有问过PDF去除水印的方法,现在在网上下载一些PDF电子书,几乎页面内都会有水印的,而且有的水印还带有超链接,稍微不注意就会点开进入别的页面内,不仅影响了阅读效果还带给读者负面影响,那如 ...

  10. BAT加密最终版

    %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a %%a ...