登陆{
本地的话直接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. 如何获取下载 FreeBSD

    『如何获取下载 FreeBSD 』 『如何获取下载 FreeBSD 』 FreeBSD 是免费获取的. [下载地址] O网页链接 版本选择,尽量选择较新版本,桌面用户可选择 current 版本.st ...

  2. C# 应用 - 封装类访问 Postgresql 数据库

    引入库类 连接数据库 访问数据库 1)增删改数据库 2)查数据库 数据转换 事务 1. 引入库类 引入 Npgsql.dll using Npgsql; using NpgsqlTypes; 2. 连 ...

  3. 运维小姐姐说这篇Consul集群和ACL配置超给力(保姆级)

    前言 上一篇简单介绍了Consul,并使用开发模式(dev)进行流程演示,但在实际开发中需要考虑Consul的高可用和操作安全性,所以接着来聊聊集群和ACL的相关配置,涉及到的命令会在环境搭建过程中详 ...

  4. Python脚本打包成exe执行文件

    需求 一个教辅目录结构检查工具,目录结构是[书籍]-[章节]-[题目|答案]-[*.jpg],后台有个异步处理的服务,需要强依赖这个目录结构. 书籍解析是单独的pipeline,日志对用户不可见,这里 ...

  5. 博文推荐|多图详解 Apache Pulsar 消息存储模型

    关于 Apache Pulsar Apache Pulsar 是 Apache 软件基金会顶级项目,是下一代云原生分布式消息流平台,集消息.存储.轻量化函数式计算为一体,采用计算与存储分离架构设计,支 ...

  6. [Fundamental of Power Electronics]-PART I-6.变换器电路-6.2 变换器简单罗列

    6.2 变换器简单罗列 变换器的数量可能有无穷种,因此将其全部列出是不可能的.这里给出了一个简单的罗列清单. 首先考虑含单个电感的单输入单输出变换器的类别.可以在电源和负载之间进行连接电感的方法数量是 ...

  7. 轻松理解 Spring AOP

    目录 Spring AOP 简介 Spring AOP 的基本概念 面向切面编程 AOP 的目的 AOP 术语和流程 术语 流程 五大通知执行顺序 例子 图例 实际的代码 使用 Spring AOP ...

  8. CIE标准色度系统(下)

    四.色温与相关色温 根据绝对黑体光谱分布特性的普朗克定律,由普朗克公式可以计算出黑体对应于某一温度的光谱分布,并由此应用CIE标准色度系统可获得该温度下黑体发光的三刺激值和色品坐标,从而在色品图上得到 ...

  9. 配置Jupyter环境:安装+补全+美化+常用库

    1 Jupyter简介 Jupyter Notebook是一个交互式笔记本,支持运行40多种编程语言,本质是一个Web应用程序,便于创建和共享文学化程序文档,支持实时代码,数学方程,可视化和Markd ...

  10. HashSet、CopyOnWriteArraySet、ConcurrentSkipListSet源码解析(JDK1.8)

    目录 HashSet源码解析 HashSet简单使用的demo HashSet中的变量 HashSet的构造函数 HashSet的add方法 HashSet的iterator方法 HashSet的si ...