基础

1.查看所有数据库:

show dbs

2.选择数据库:

use test

3.查看数据库中有哪些集合:

show collections

如下图:

查询

1.查看集合中有哪些数据,其中abc为集合名称:

2.为查询添加过滤条件a=2:

3.指定查询结果集中包含的字段,如下查询仅包含字段a/b,注意,此处除了_id字段外,其他字段要么全是1,要么全是0:

4.综合示例:

db.kpiRecord.find(
{
cellCode:"48BF74_12020000051TST0001",
startTime: {
$gte: new ISODate("2018-06-01T00:00:00Z")
},
startTime: {
$lt: new ISODate("2018-06-01T01:00:00Z")
}
},
{
_id:,
cellCode:,
startTime:,
kpiNameLalalalala0000:
}
)

如下图:

插入

1.添加一条记录:

db.abc.insertOne({"" : "123-val", "a" : , "b" : })

如下图:

2.添加多条记录:

db.abc.insertMany([
{"" : "123-val0", "a" : , "b" : },
{"" : "123-val1", "a" : , "b" : }
])

如下图:

更新

按筛选条件更新数据:

db.abc.updateMany(
{
a: {$gt : }
},
{
$set: {"b": , "": }
}
)

如下图:

删除

1.根据条件删除集合中的数据:

db.abc.deleteMany({
a : {$gte : }
})

如下图:

2.删除集合,其中abc为集合名称:

3.删除数据库,其中pm为数据库名称:

聚合

先根据cellCode字段和startTime字段进行筛选,再根据cellCode进行聚合,计算出总和、最大值、最小值、平均值,其中pretty()方法只是为了以更整齐的方式显示结果:

db.kpiRecord.aggregate([
{
$match: {
cellCode:"48BF74_12020000051TST0001",
startTime: {$gte: new ISODate("2018-06-01T00:00:00Z")},
startTime: {$lt: new ISODate("2018-06-01T01:00:00Z")}
}
},
{
$group: {
_id: "$cellCode",
count: { $sum: },
sum: {$sum: "$kpiNameLalalalala0000"},
max: {$max: "$kpiNameLalalalala0000"},
min: {$min: "$kpiNameLalalalala0000"},
avg: {$avg: "$kpiNameLalalalala0000"}
}
}
]).pretty()

如下图:

限制条件:
(1).结果集document大小限制:结果集中,每一个document的大小不得超过16M。注意仅是限制结果集,处理过程中,document的大小是可以超过这个限制的。
(2).内存限制:Stages所能使用的内存不能超过100M。对于一些数据量较大的聚合计算,100M不够用,这时,需要指定allowDiskUse属性,从而允许MongoDB向临时文件中写数据。注意,对于$graphLookup操作符,allowDiskUse不生效。

另外,这里介绍的聚合方式是pipeline,最基本的聚合方式,MongoDB还有更复杂但也更强大的聚合方式,如Map-reduce,具体可查阅官方文档。

脚本导入

官方文档的链接:

https://docs.mongodb.com/manual/tutorial/write-scripts-for-the-mongo-shell/

语法差异

1.有一些语句,在mongo shell中可以执行,但在脚本中是无法执行的,需要换一种写法。下表中列出了转换写法。

2.查询语句,需要按如下方式书写:

cursor = db.collection.find();
while ( cursor.hasNext() ) {
printjson( cursor.next() );
}

示例

1.写一个脚本,如下是一个示例:

db.abc.updateMany({"field_a":"a-v-0"}, { $set: {"field_b": "update-newodododo"} })
db.abc.insertMany([
{ "field_a" : "js-new-a", "field_b" : "js-new-b", "field_c" : "js-new-c" },
{ "field_a" : "js-new-a-1", "field_b" : "js-new-b-1", "field_c" : "js-new-c-1" }
])

2.导入脚本,有两种方式:一是从命令行直接执行导入,二是先登入mongo shell再执行导入

2.1.第一种方式,命令行直接导入:

mongo -u "username" -p "password" --authenticationDatabase="admin" ./mongo-operation-script.js

2.2.第二种方式,从mongo shell执行导入:

load("/root/mongo-operation-script.js")

MongoDB基本增删改查操作-mongo shell的更多相关文章

  1. Scala对MongoDB的增删改查操作

    =========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...

  2. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  3. Mongodb之增删改查操作

    一.创建一个数据库 在我们使用MongoDB数据库时引进了这样一个知识,“对于mongodb,使用了不存在的对象,就等于在创建这个对象”,所以创建数据库的操作就比较简单 在我们使用mysql数据库时u ...

  4. Node.js对MongoDB进行增删改查操作

    MongoDB简介 MongoDB是一个开源的.文档型的NoSQL数据库程序.MongoDB将数据存储在类似JSON的文档中,操作起来更灵活方便.NoSQL数据库中的文档(documents)对应于S ...

  5. MongoDB之增删改查(一)

    本文主要介绍MongoDB数据库增删改查操作. 增 mongoDB和其它关系型数据库一样,通过insert来添加数据到集合中去. db.collectionName.insert(内容) 显示数据库中 ...

  6. python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

    python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

  7. C# 对MongoDB 进行增删改查的简单操作

    C# 对MongoDB 进行增删改查的简单操作   下面演示下C#操作MongoDB驱动的简单的增删改查代码 运用到的MongoDB支持的C#驱动,当前版本为1.6.0 1,连接数据库   /// & ...

  8. SpringBoot操作MongoDB实现增删改查

    本篇博客主讲如何使用SpringBoot操作MongoDB. SpringBoot操作MongoDB实现增删改查 (1)pom.xml引入依赖 <dependency> <group ...

  9. Java连接MongoDB进行增删改查

    1.导入必须的包: 详情看项目:http://pan.baidu.com/s/1cvDAOY 2.通过Myeclipse创建WEB项目 3. 3.bean:创建实体类 package com.bean ...

随机推荐

  1. 设计模式20:Memento 备忘录模式(行为型模式)

    Memento 备忘录模式(行为型模式) 对象状态的回溯 对象状态的变化无端,如何回溯.恢复对象在某个点的状态? 动机(Motivation) 在软件构建过程中,某些对象的状态在转换过程中,可能由于某 ...

  2. Javascript事件触发顺序

    html标签是有子和父的,这个时候就出现了事件触发顺序的问题,比如: <!DOCTYPE html> <html> <head> <style> .fi ...

  3. CSS中的一些内容总结

    一.选择器 1.选择器的分组:一个Style可以对多个选择器生效,只用在不同的选择器中间加入逗号即可.如: h1,h2,h3,h4,h5,h6 { color: green; } PS:CSS规定,所 ...

  4. MIDA Converter Basic patched for RAD Studio 10.1.2 Berlin (VCL转换到FMX)

    Mida is the only way to try to convert your project from VCL to FireMonkey. Version after version, M ...

  5. What is the difference between inverse converse and reverse?

    http://wiki.answers.com/Q/What_is_the_difference_between_inverse_converse_and_reverse First, it help ...

  6. ffmpeg用法小结,教你抓各大网站视频

    最近受邀朋友帮忙需要抓取一段某酷电影,偶然间发现ffmpeg程序.说到此可能会有人提到you-get和youtube-dl,期间也接触了该两款程序,但是由于版权原因,该软件仅仅可以抓取前几分钟预览版, ...

  7. C# Log4.Net日志组件的应用系列(二)

    引言 Log4Net应该可以说是.NET中最流行的开源日志组件了.在各种项目框架中可以说是必不可少的组成部分.个人认为Log4Net有下面几个优点: 1. 使用灵活,它可以将日志分不同的等级,以不同的 ...

  8. pageadmin CMS Sql新建数据库和用户名教程

    用pageadmin网站制作如何Sql新建数据库和用户名 sql server软件安装完毕后,需要新建一个数据库用来作为网站的数据库. 1.打开sql管理界面,如图所示,找到数据库,右键单击数据库,选 ...

  9. libz.dylib框架怎么导入

    1.General下 2.点击+号在弹出的对话框选择addother 3.在弹出的对话框中输入"cmd"+"shift"+"g" 输入/us ...

  10. 用户画像,知乎Live总结

    ttps://www.zhihu.com/lives/889189116527403008/messages 用户画像两层含义:单个标签:用户的分布 标签体系要与时俱进,如果标签被下游强依赖,则不轻易 ...