登陆{
本地的话直接mongo,如果是docker直接就这样docker exec -it 2d71a13e3128 mongo
或者直接这样 mongo 127.0.0.1:27017
}
退出是 {
exit
} database级操作{
查看服务器上的数据库{
show dbs
}
切换数据库 {
use data
}
查看所有集合{
show collections
}
创建数据库 {
mongo中创建数据库采用的也是use命令,如果use后面跟的数据库名不存在,那么mongo将会新建该数据库。不过,实际上只执行use命令后,mongo是不会新建该数据库的,直到你像该数据库中插入了数据。use test2
db.hello.insert({"name":"testdb"}) 该操作会在test2数据库中新建一个hello集合,并在其中插入一条记录
}
查询{
db.getCollection('数据集合').find({条件})
如果想格式化输出,可以直接后面追加.pretty()
}
删除当前数据库 {
db.dropDatabase() **/在主服务器上操作的时候要慎重
}
查看当前数据库{
db
}
} collection级操作
{
新建collection{
db.createCollection("Hello") [直接向一个不存在的Collection里写一条数据,会默认直接创建这个Collection]
}
删除collectio{
db.Hello.drop()
}
重命名{
db.hello2.renameCollection("HELLO")
}
查看当前数据库中的所有collection{
show collections
}
建立索引在HELLO集合上,建立对ID字段的索引,1代表升序。{
db.HELLO.ensureIndex({ID:1})
}
} Record级的操作
{ 插入{
向A集合中插入两条记录{
db.A.insert({'name':'Gal Gadot','gender':'female','age':28,'salary':11000})
db.A.insert({'name':'Mikie Hara','gender':'female','age':26,'salary':7000})
}
同样也可以用save完成类似的插入操作 {
db.A.save({'name':'Wentworth Earl Miller','gender':'male','age':41, 'salary':33000})
}
}
查找{
查找A集合中的所有记录{
db.A.find()
}
Exact Equa:查找集合中的符合条件的记录{
单一条件:查询age为了28的数据. db.A.find({'age':28})
}
Great Than:大于{
查询salary大于10000的数据 db.A.find({salary:{$gt:10000}})
}
Fuzzy Match:包含{
查询name中包含'l'的数据 db.A.find({name:/l/})
查询name以G打头的数据 db.A.find({name:/^G/})
}
查找条件是某个字段是否存在{
查找A集合中存在ID字段的{
db.A.find({ID:{$exists:true}})
}
}
多条件"与"{
查询age小于30,salary大于10000的数据
db.A.find({age:{$lt:30},salary:{$gt:10000}})
}
多条件“或”{
查询age小于30,或者salary大于10000的记录
db.A.find({$or:[{salary:{$gt:10000}},{age:{$lt:30}}]})
}
查询第一条记录 findOne(){
返回上面的那个例子的第一条db.A.findOne({$or:[{salary:{$gt:10000}},{age:{$lt:30}}]})
}
查询记录的指定字段{
只显示name字段(没有name的只显示_id,有的同时显示_id和name) db.A.find({},{name:1})
}
查询指定字段的数据,并去重{
查询gender字段的数据,并去掉重复数据 db.A.distinct('gender')
}
对查询结果集的操作{
Pretty Print {
Mongo里面有两个格式化输出方法{
db.collection.pretty()
db.collection.forEach(printjson)
}
指定结果集显示的条目{
显示结果集中的前3条记录{
db.A.find().limit(3)
}
查询第2条以后的所有数据(跳过){
db.A.find().skip(2)
}
对结果集排序{
按照salary字段进行升序或者降序排序,如果没有salary字段的话,就默认为最小,比负数还小,就当他是无穷小。
db.A.find().sort({salary:1})
db.A.find().sort({salary:-1})
}
输出结果条数{
db.A.find().count()
}
删除数据{
删除集合里所有数据 db.A.remove({})
删除定义了y字段的数据 db.test.remove({y:{$exists:true}})
也可以只删除固定条数db.test.remove({x:{$exists:true}},1)
tip:
db.collection.remove是删除了集合中所有的记录,原有的索引等信息还在,而db.collection.drop()是把整个集合都删除掉(包括索引)
}
}
更新操作{
db.collection.update(criteria, objNew, upsert, multi )
criteria:update的查询条件,类似sql update查询内where后面的
objNew:update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的。
upsert : 如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新
例子{
db.test.update({x:'x'},{$set:{x:'2'}},false,false) 把集合test中x='x'的中的x改成‘2’,如果没有找到就不该,并且如果找到多条,只改动第一条
db.test.update({x:'x'},{$set:{x:'2'}},false,true) 跟上面的区别是如果找到多条,那么全都改动。
db.test.update({x:'x'},{$set:{w:'2'}},true,true) 跟上一条的区别是,如果没查到x:'x'那么久单独创建一条记录,如果查到了x:'x'但是没有w这个字段,那么就创建这个字段。同时如果条件是不等式那样的条件,那么当创建新的记录的时候,不会出现条件字段。只会出现后面的设置的字段。比如
db.test.update({w:'x'},{$set:{q:'2'}},true,true) 如果不存在w这个字段,则是创建新的记录 {w:'x',q:'2'},而
db.test.update({w:{$lt:30}},{$set:{q:'2'}},true,true) 如果不存在w字段,那么创建新的一条数据{q:'2'}其中是没有w字段的。
}
}
}
$gt:大于
$lt:小于
$gte:大于或等于
$lte:小于或等于
不等于 $ne
这里还有一篇其他小伙伴整理的
https://blog.csdn.net/AlbertFly/article/details/83001012
mongodb中的insert和save的区别
https://blog.csdn.net/qq_38603247/article/details/82633745

官方文档

https://docs.mongodb.com/manual/storage/

mongoDB常用的更多相关文章

  1. (转)mongodb常用命令脚本化-自动化运维

    mongodb常用命令脚本化-自动化运维 把一些运维中常用到的mongodb命令写成shell脚本,极大的方便了维护   1 设置副本集   #!/bin/bash#mongodb 进入client ...

  2. mongodb常用操作语句

    mongodb常用操作语句 A:创建数据表 db.createCollection(name, {capped: <Boolean>, autoIndexId: <Boolean&g ...

  3. mongodb 常用的命令

    mongodb 常用的命令 对数据库的操作,以及登录 1 进入数据库 use admin 2 增加或修改密码 db.addUser('wsc', '123') 3查看用户列表 db.system.us ...

  4. MongoDB 常用的几大GUI工具

    MongoDB 常用的几大GUI工具 MongoDBCompass (官方的连接工具),免费的,界面简洁,不支持 sql 查询,支持性能监控.支持在三大平台 Windows .Mac .Linux 上 ...

  5. mongodb常用语句(集合操作)

    mongodb常用语句(集合操作) 查看集合帮助 db.songs.help(); 查看集合总数据量 db.songs.count(); 查看表空间大小 db.songs.dataSize(); 查看 ...

  6. mongodb常用命令学习笔记

    mongodb常用命令学习笔记 创建数据库 use DATABASE_NAME eg: use users; 如果数据库不存在,则创建数据库,否则切换到指定数据库.要显示刚刚创建的数据库,需要向数据库 ...

  7. MongoDB常用操作命令大全

    成功启动MongoDB后,再打开一个命令行窗口输入mongo,就可以进行数据库的一些操作.输入help可以看到基本操作命令,只是MongoDB没有创建数据库的命令,但有类似的命令 如:如果你想创建一个 ...

  8. MongoDB常用命令

    本文整理了一年多以来我常用的MongoDB操作,涉及mongo-shell.pymongo,既有运维层面也有应用层面,内容有浅有深,这也就是我从零到熟练的历程. MongoDB的使用之前也分享过一篇, ...

  9. MongoDB常用操作

    (备注: 对于 window, 不需要sudo) 验证成功与否: * 启动服务器: $sudo mongod --dbpath C:\data\db (需要 指明数据库存放的目录) * 打开shell ...

  10. mongodb常用命令【转】

    mongodb由 C++编写,其名字来自humongous这个单词的中间部分,从名字可见其野心所在就是海量数据的处理.关于它的一个最简洁描述为:scalable, high-performance, ...

随机推荐

  1. 测试平台系列(3) 给Hello World添加日志

    给Hello World添加日志 回顾 通过上篇内容,我们已经使用「Flask」完成了我们的第一个接口.我们可以看到,使用「Flask」来编写接口是十分简单的.那么接下来,我们丰富一下上面的例子. 需 ...

  2. [Redis知识体系] 一文全面总结Redis知识体系

    本系列主要对Redis知识体系进行详解.@pdai Redis教程 - Redis知识体系详解 知识体系 学习资料 知识体系 知识体系 相关文章 首先,我们通过学习Redis的概念基础,了解它适用的场 ...

  3. pytest进阶之fixture函数

    fixture函数存在意义 与python自带的unitest测试框架中的setup.teardown类似,pytest提供了fixture函数用以在测试执行前和执行后进行必要的准备和清理工作.但是相 ...

  4. 【linux】系统编程-3-system-V IPC 信号量

    目录 前言 5. 信号量 5.1 概念 5.2 工作原理 5.3 操作函数 5.3.1 semget() 5.3.2 semop() 5.3.3 semctl() 5.4 例程 参考: 前言 原文链接 ...

  5. [源码解析] 并行分布式框架 Celery 之 worker 启动 (1)

    [源码解析] 并行分布式框架 Celery 之 worker 启动 (1) 目录 [源码解析] 并行分布式框架 Celery 之 worker 启动 (1) 0x00 摘要 0x01 Celery的架 ...

  6. CentOS7使用NTP搭建时间同步服务器

    前言 为什么要搭建时间同步服务器呢?场景是这样的. 我们有两台CentOS服务器,其中一台是可以连接外网的,下文中我们称它为A服务器,另一台不能连接外网,但是与A服务器在同一局域网中,下文中我们称它为 ...

  7. .Net Core3.1中SameSite的使用方法、遇到的问题以及解决办法

    一.关于SameSite的介绍 1.  什么是SameSite? SameSite是浏览器请求中Set-Cookie响应头新增的一种属性,它用来标明这个 cookie 是否是"同站 cook ...

  8. Nginx错误日志(error_log)配置及信息详解

    Nginx错误日志信息介绍 Nginx的错误信息是调试Nginx服务的重要手段,属于核心功能模块(ngx_core_module)的参数,该参数的名字为error_log,可以放在Main区块中全局配 ...

  9. 第20 章 : GPU 管理和 Device Plugin 工作机制

    GPU 管理和 Device Plugin 工作机制 本文将主要分享以下几个方面的内容: 需求来源 GPU 的容器化 Kubernetes 的 GPU 管理 工作原理 课后思考与实践 需求来源 201 ...

  10. 不想eject,还咋修改create-react-app的配置?

    一.先抛问题 许多刚开始接触create-react-app框架的同学,不免都会有个疑问:如何在不执行eject操作的同时,修改create-react-app的配置.今天胡哥就来带大家一起来看看这个 ...