MongoDB系列----查
开启查询:
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系列----查的更多相关文章
- MongoDB系列(二):C#应用
前言 上一篇文章<MongoDB系列(一):简介及安装>已经介绍了MongoDB以及其在window环境下的安装,这篇文章主要讲讲如何用C#来与MongoDB进行通讯.再次强调一下,我使用 ...
- MongoDB系列之二(主动复制)
目前我正在进行MongoDB的双机热备方面相关的工作.根据我目前看到的MongoDB方面的材料,MongoDB的实际部署有三种方式,分别是“主动复制”,“副本集”以及“分片副本集”. 首先我们从最简单 ...
- mongodb系列之---副本集配置与说明
在配置副本集之前,我们先来了解一些关于副本集的知识. 1,副本集的原理 副本集的原理与主从很相似,唯一不同的是,在主节点出现故障的时候,主从配置的从服务器不会自动的变为主服务器,而是要通过手动修改配置 ...
- MongoDB 系列文章
MongoDB 系列文章 本文的内容是基于 MongoDB 4.0 的. 参考于 MongoDB 4.0 官方文档. 搭建 MongoDB从搭建到优化 MongoDB-副本集搭建与管理 管理 Mong ...
- mongoDB系列之(二):mongoDB 副本集
1. 什么是副本集 副本集就是mongoDB副本所组成的一个集群. 同期原理是,写操作发生在主库,从库同步主库的OpLog日志. 集群中没有特定的主库,主库是选举产生,如果主库down了,会再选举出一 ...
- mongodb系列之-治理mongodb->db.currentOp()
mongodb系列之-管理mongodb->db.currentOp() 管理mongodb->db.currentOp(), 绝对是原创... 今天公司的dba在内部分享了针对mysql ...
- 14.MongoDB系列之配置分片
1. 启动服务器 1.1 启动配置服务器 配置服务器是集群的大脑,保存着关于每个服务器包含哪些数据的所有元数据,因此,必须首先创建配置服务器. 由于资源限制,在同一机器上启动三个进程 # mkdir ...
- MongoDB系列(三):增删改查(CURD)
上篇讲了MongoDB的基础知识,大家应该对MongoDB有所了解了,当然真正用的还是curd操作,本篇为大家讲解MongoDB的curd操作. 1.数据库操作 #.增 use config #如果数 ...
- MongoDB系列---用户及权限管理02
MongoDB-——Privilege 学习大纲: 1.用户权限管理 2.用户操作 知识回顾: 本系列上一篇博文我们讲述了如何搭建环境以及配置我们的MongoDB,通过搭建环境后我们又学习了如何通过 ...
随机推荐
- 一些值得深入学习和借鉴的 .Net 开源项目
1.DotNetFramework .NET Reference Source 发布了 beta 版,可以在线浏览 .NET Framework 4.5.1 的源代码,并且可以通过配置,在 Visu ...
- BZOJ3160 万径人踪灭 字符串 多项式 Manachar FFT
原文链接http://www.cnblogs.com/zhouzhendong/p/8810140.html 题目传送门 - BZOJ3160 题意 给你一个只含$a,b$的字符串,让你选择一个子序列 ...
- 使用apt-get安装相关的软件时,不能Fetch,现在更新为国内的源!
我使用的是中国科技大学的树莓派的软件源,测试可以使用(更新时间:2018年7月15日) deb http://mirrors.ustc.edu.cn/raspbian/raspbian/ jessie ...
- git命令详解( 六 )
此为git命令的第六篇 远程跟踪分支 不知道大家有没有发现在前面几篇中Git 好像知道 master 与 o/master 是相关的.当然这些分支的名字是相似的,可能会让你觉得是依此将远程分支 mas ...
- RAID 0 ~ RAID 7
一.RAID解析1.RAID 0(1)将几块磁盘并行组合,横向写数据(2)并发IO,写数据最快缺点:不提供数据冗余,如果其中一块磁盘废掉,则数据全毁详细:条带深度大时,一次IO只能从一块磁盘上读取,无 ...
- 潭州课堂25班:Ph201805201 tornado 项目 第十一课 项目改进和优化(课堂笔记)
使用 Bootstrap 前端框架 可以在 bootCDN 这里找 jquery ,poppe.js 文件 当聊天室发来一第图片链接时,自动保存图片到服务器,并保存相关信息到数据库,系统向该用户发出 ...
- Node.js_ express.Router 路由器_模块化管理路由
路由器 express.Router 路由器 模块化管理 路由 基本使用: 路由模块 1. 引入 express const express = require('express'); 其他相关模块 ...
- 变量类型-List
教程:一:列表的创建 List(列表) 是 Python 中使用最频繁的数据类型.列表中元素的类型可以不相同,数字,字符串甚至可以包含列表(所谓嵌套) (1)List写在方括号之间,元素用逗号隔 ...
- 男默女泪,ArcGIS AddIN 编辑逻辑赏析,走过路过,不要错过
看到了一段ESRI写的一个工具,我反编译了一下,学习工具中的几个代码片段 一. IEditTask task = (this._editor as IEditTaskSearch).get_TaskB ...
- Appium-Python-Windows环境搭建笔记
Appium版本:1.11.0 操作系统:Windows7-64位 开发语言:Python 3.7.2 测试应用平台:安卓 5.1.1 Appium服务端 一.JDK 也许你会觉得很奇怪,我搭建Pyt ...