MongoDB常用命令大全,概述、备份恢复

文章目录

  • 一、MongoDB简介
  • 二、服务启动停止、连接
  • 三、数据库相关
  • 四、集合操作
  • 五、文档操作
  • 六、数据备份与恢复/导入导出数据
    • 6.1 mongodump备份数据库
    • 6.2 mongorestore还原数据库
    • 6.3 mongoexport导出表 或 表中部分字段
    • 6.4 mongoimport导入表 或 表中部分字段
  • 七、其他常用命令
  • 八、补充

还记得MySQL、Redis、PostgreSQL、ClickHouse常用命令及操作吗?如果忘记可以到这里重新温习: MySQL常用命令,Redis常用命令,PostgreSQL常用命令,ClickHouse常用命令,启动、关闭、连接、备份、导入导出。本文重点讲述MongoDB常用命令。

一、MongoDB简介

MongoDB是一款流行的NoSQL数据库,以其灵活的文档模型、高可用性、易于扩展等特性而受到广泛关注。

  • MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统;在高负载的情况下,添加更多的节点,可以保证服务器性能;MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案;MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成;MongoDB 文档类似于 JSON 对象。
  • 特点:高性能、高可用、高扩展、丰富的查询支持、动态模式和灵活的文档模型
  • 应用场景:网站实时数据处理;缓存;高伸缩性的场景

MongoDB中的记录是一个文档,它是由字段和值对组成的数据结构。多个键及其关联的值有序地放在一起就构成了文档。MongoDB文档类似于JSON对象。字段的值可以包括其他文档,数组和文档数组。{“greeting”:“hello,world”, “foo”: 3}

在MongoDB中基本的概念是文档、集合、数据库。

SQL术语/概念MongoDB术语/概念解释/说明
databasedatabase数据库
tablecollection数据库表/集合
rowdocument(集合中的数据)数据记录行/文档
columnfield数据字段/域
indexindex索引
table joins表连接,MongoDB不支持
primary keyprimary key主键,MongoDB自动将_id字段设置为主键

数据库服务和对应的客户端

数据库服务客户端
Mysqld/Oraclemysql/sqlplus
mongodbmongo

在MongoDB中,常用命令包括数据库操作、集合操作、文档操作等几个方面。以下是MongoDB的一些常用命令及其说明

二、服务启动停止、连接

#windows cmd   或   Linux 终端
mongo --version

#启动
#Windows启动与停止    命令行指令、任务管理器手动启动停止
#以管理员方式运行cmd,输入以下命令
net start mongodb
net stop mongodb    #停止mongodb服务
netstat -aon | findstr 27017

#Linux启动与停止
/xxx/mongodb-server/bin/mongod -f /xxx/mongodb-server/conf/mongodb.conf     #启动
ps -ef | grep mongodb-server
netstat -tunlp | grep 27017
ps -aef | grep mongodb-server | grep -v grep | awk '{print $2}' | xargs -t kill -9           #停止


#连接mongodb
#配置了环境变量的前提下 在任意目录可通过mongo进入数据库;否则需要在mongodb安装目录下操作
mongo        #无密码
mongo 10.169.215.xx:27017/admin  -uroot  -p1234    #有密码
mongo localhost:27017/admin -uroot -p密码     
mongo admin -uroot -p密码

已开启认证的,除了mongo 10.169.215.xx:27017/admin -uroot -p1234连接;还可以通过 mongo进入命令行,使用use admin通过db.auth(‘root’,‘密码’) 输出1就是验证成功。

在这里插入图片描述

windows下启动、停止、查看mongodb

在这里插入图片描述

linux下启动、停止、查看mongodb

在这里插入图片描述

三、数据库相关

  1. 连接数据库
    • 使用MongoDB Shell连接:mongo [host]:[port]/[dbname],其中[host]是数据库服务器地址,[port]是端口号(默认为27017),[dbname]是数据库名。如果连接本地数据库,可以简化为mongomongo localhost;有密码则需要加上对应的参数 -u、-p
    • 使用完整连接字符串:mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
  2. 查询所有数据库
    • 命令:show dbsshow databases
  3. 创建/切换数据库
    • 命令:use database_name。如果数据库不存在,则创建并切换到该数据库;如果数据库已存在,则直接切换到该数据库。
  4. 删除数据库
    • 先切换到要删除的数据库,然后执行命令:db.dropDatabase()
  5. 查看当前使用的数据库
    • 命令:dbdb.getName()
  6. 显示数据库中的用户: show users
#mongodb命令行
show dbs                 #查询所有数据库
use database_name        #创建/切换数据库
db.dropDatabase()        #删除数据库
db 或 db.getName()       #查看当前使用的数据库
show users               #显示数据库中的用户

在这里插入图片描述

四、集合操作

  1. 创建集合
    • 命令:db.createCollection(name, options)。其中name是集合名称,options是可选参数,用于指定集合的特性,如固定集合(capped collection)的大小和最大文档数。
    • 集合的隐式创建:当向一个集合中插入一个文档的时候,如果集合不存在,则会自动创建集合。 提示:通常我们使用隐式创建文档即可
  2. 查看所有集合
    • 命令:show collectionsshow tables
  3. 删除集合
    • 命令:db.collection_name.drop()。成功删除集合将返回true,否则返回false
  4. 查询当前集合的数据条数:db.yourCollec.count()
#mongodb命令行
use wjTemp                    #如果wjTemp数据库不存在,则创建并切换到该数据库;如果数据库已存在,则直接切换到该数据库
db.createCollection("myCollec")    #创建myCollec集合
db.createCollection("myCollec2")
db.createCollection(“collName”, {size: 20, capped: 5, max: 100});
show tables                        #查看所有集合
db.myCollec2.drop()                #删除myCollec2集合
show collections

db.getCollection("account")        #得到指定名称的聚集集合(table)
db.getCollectionNames()            #得到当前db的所有聚集集合
db.printCollectionStats()          #显示当前db所有聚集索引的状态

在这里插入图片描述

五、文档操作

  1. 插入文档:使用 insertsave 方法插入文档(‌在较新的 MongoDB 版本中,‌save 方法已被弃用,‌推荐使用 insertOneinsertMany)‌
    • 单条插入:db.collection_name.insert(document)db.collection.insertOne(document)
    • 多条插入:db.collection_name.insert([document1, document2, ...])db.collection.insertMany([document1, document2, ...])
  2. 查询文档
    • 查询所有文档:db.collection_name.find()。相当于 select * from collection_name
    • 查询满足条件的文档:db.collection_name.find(query),其中query是查询条件。
    • 格式化显示查询结果:db.collection_name.find().pretty()
    • 查询并返回第一个匹配的文档:db.collection_name.findOne(query)
  3. 更新文档:update、updateOne、updateMany
    • 使用update方法:db.collection.update(<query>, <update>, {upsert: <boolean>, multi: <boolean>})。其中query是查询条件,类似sql update查询内where后面的;update是更新内容,也可以理解为sql update查询内set后面的;upsert 可选,表示如果不存在满足条件的文档,是否插入新文档(默认为false);multi 可选,表示是否更新所有满足条件的文档(默认为false,只更新第一个)。
    • 使用$set操作符更新字段:db.collection.update(query, {$set: {field: value}})
  4. 删除文档:remove、deleteOne、deleteMany
    • 删除满足条件的文档:db.collection.remove(query, {justOne: <boolean>})。其中query是删除条件,justOne表示是否只删除第一个匹配的文档(默认为false,删除所有匹配的文档)。
    • 使用deleteOnedeleteMany方法(MongoDB 3.2+):db.collection.deleteOne(query)db.collection.deleteMany(query)
#插入、查询、删除
db.myCollec.insert({title: 'MongoDB', 
    description: 'MongoDB NOSQL',
    by: 'test',
    url: 'https:',
    tags: ['mongodb', 'database', 'NoSQL'],
    likes: 100
})
db.myCollec.find()
db.myCollec.update({'title':'MongoDB'},{$set:{'title':'MongoDB-test'}})
db.myCollec.remove({'title':'MongoDB-test'})



#查询
db.userInfo.find()                    #查询所有记录
db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)   #分页列表查询。使用limit()方法来读取指定数量的数据,使用skip()方法来跳过指定数量的数据
db.userInfo.distinct("name")          #查询去掉后的当前聚集集合中的某列的重复数据。会过滤掉name中的相同数据,相当于:select distict name from userInfo
db.userInfo.find({"age": 23})         #查询age = 23的记录,相当于 select * from userInfo where age = 23
db.userInfo.find({age: {$gt: 23}})    #查询age > 23的记录
db.userInfo.find({age: {$gte: 25}})   #查询age >= 25的记录
db.userInfo.find({name: /mongo/})     #查询name中包含 mongo的数据,//相当于%%,相当于 select * from userInfo where name like ‘%mongo%’
db.userInfo.find({name: /^mongo/})    #查询name中以mongo开头的,select * from userInfo where name like ‘mongo%’
db.userInfo.find({}, {name: 1, age: 1})   #查询指定列name、age数据,相当于:select name, age from userInfo
db.userInfo.find({age: {$gt: 25}}, {name: 1, age: 1})   #查询指定列name、age数据, age > 25。相当于:select name, age from userInfo where age >25
#按照年龄排序
db.userInfo.find().sort({age: 1})    #升序
db.userInfo.find().sort({age: -1})   #降序
db.userInfo.find({name: 'zhangsan', age: 22})   #查询name = zhangsan, age = 22的数据。相当于:select * from userInfo where name = ‘zhangsan’ and age = ‘22’;
db.userInfo.find().limit(5)    #查询前5条数据。相当于:selecttop 5 * from userInfo;
db.userInfo.find().skip(10)    #查询10条以后的数据。相当于:select * from userInfo where id not in (selecttop 10 * from userInfo)
db.userInfo.find().limit(10).skip(5)  #查询在5-10之间的数据。可用于分页,limit是pageSize,skip是第几页*pageSize
db.userInfo.find({sex: {$exists: true}}).count()   #按照某列进行排序。相当于:select count(sex) from userInfo

在这里插入图片描述

六、数据备份与恢复/导入导出数据

  • 定时备份/全量备份

    • 备份 mongodump,还原 mongorestore

    • 备份格式: bson/gzip

  • 分析数据/迁移数据

    • 备份 mongoexport,还原 mongoimport

    • 备份格式:json csv

常见备份恢复方法

1)备份全库、单个库:

mongodump --host mongodb1.example.net --port 27017 -u用户名 -p密码 --db mydbname --out /path/to/backup/
mongorestore --host mongodb2.example.net --port 27017 -u用户名 -p密码 --db mydbname /path/to/backup/mydbname/


mongodump -h ip:端口 -uroot -p密码 -d 数据库 -o 路径             #备份数据库
mongodump -uroot -p密码 -d 数据库 -c 集合名 -o 路径    #备份数据库某个集合
mongorestore -h 127.0.0.1:27017 -u用户名 -p密码 -d 数据库 --dir /路径/数据库名/

#加密后备份
mongodump -h ip:port -uroot -p密码 -d 数据库 --authenticationDatabase admin -o 路径         
mongodump -uroot -p密码 -d 数据库 -c 集合名 --authenticationDatabase admin -o 路径   

mongorestore -uroot -p密码 -d wjTemp2 --authenticationDatabase admin --dir /root/mon_wjTemp/wjTemp/

在这里插入图片描述

2)备份某个库的某张表:

mongoexport备份

mongoexport备份某个表语法格式:mongoexport --port 端口号 -d 库名 -c 表名 -o 备份文件路径.json

mongoexport备份某个表csv格式:mongoexport --port 端口号 -d 库名 -c 表名 --type=csv -f 备份的字段 -o 备份文件路径.csv

mongoimport还原

mongoimport还原某个表json格式:mongoimport --port 26017 -d 要还原的库名-c 表名 备份文件路径.json

mongoimport还原某个表csv格式: mongoimport --port 26017 -d 库名 -c 表名–type=csv --headerline 备份文件路径.csv

(mongoimport还原csv格式表时要加上–headerline参数,否则会将字段名也作为一条数据插入;–headerline和-f不能同时使用)

mongodump备份

mongodump备份库:mongodump --port 26017 -d 库名 -o 备份文件路径

mongorestore还原

mongorestore还原:mongorestore --port 26017 -d 库名 备份文件路径 --drop

6.1 mongodump备份数据库

常用命令格式如下:

mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -o 文件存在路径
mongodump -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 集合名 -o 文件存在路径
  • 如果没有用户,可以去掉-u和-p。
  • 如果导出本机的数据库,可以去掉-h。
  • 如果是默认端口,可以去掉–port。
  • 如果想导出所有数据库,可以去掉-d
mongodump -h 127.0.0.1 -u用户名 -p密码 -o /home/dev/mongodb/      #备份所有数据库
mongodump -h ip --port 端口 -u用户名 -p密码 -d tank -o /home/dev/mongodb/   #备份指定数据库

mongodump -uroot -p密码 -d wjTemp -o /root/mon_wjTemp
mongodump -uroot -p密码 -d wjTemp --authenticationDatabase admin -o /root/mon_wjTemp

如果报错 Failed: error connecting to db server: server returned error on SASL authentication step: Authentication failed.,可以添加--authenticationDatabase admin

示例

mongodump -h 192.168.31.251:27017 -d my_db -u test_user -p test_user -o c:\mongoBackup
mongodump -h 192.168.31.251 -port:27017 -d my_db -u test_user -p test_user -o c:\mongoBackup

mongodump -uroot -p密码 -d wjTemp --authenticationDatabase admin -o /root/mon_wjTemp

6.2 mongorestore还原数据库

mongorestore --host <hostname> --port <port> --db <database> <path_to_backup>
mongorestore -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 --drop 文件存在路径

–drop的意思是,先删除所有的记录,然后恢复。

mongorestore -h ip:port -u 用户名 -p 密码 /home/dev/mongodb/  #恢复所有数据库到mongodb中。这里的路径是所有库的备份路径
mongorestore -d tank /home/dev/mongodb/tank/  #还原指定的数据库

# 使用新建用户恢复demodb数据库
mongorestore -u 用户名 -p 密码 -d db_name c:\mongoBackup\my_db --authenticationDatabase admin -u admin -p password

# 或使用admin用户恢复数据到 yuandb 数据库中
mongorestore -u admin -p admin123 -d yuandb c:\mongoBackup\my_db --authenticationDatabase admin -u admin -p admin123
#【注意:备份的数据库文件路径(c:\mongoBackup\my_db)一定要指定到xxx.bson的根目录 】

恢复前先要使用use 命令切换到要导入的数据库
在切换后的数据库下新建用户,并设置角色及所属数据库
使用新建用户或admin用户导入
使用新建的用户连接数据库
【注意:先用admin用户导入,然后再创建普通用户并设置角色及指定所属数据库,最终新建用户是无法连接数据库的】

通过以上步骤虽然能导入数据库,但是在连接时会提示授权错误,暂时就用admin一个用户就行

6.3 mongoexport导出表 或 表中部分字段

常用命令格式

mongoexport -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 -f 字段 -q 条件导出 --csv -o 文件名

上面的参数好理解,重点说一下:

  • -f 导出指定字段,以字号分割,-f name,email,age 导出name,email,age这三个字段
  • -q 可以根查询条件导出,-q ‘{ “uid” : “100” }’ 导出uid为100的数据
  • –csv 表示导出的文件格式为csv的,这个比较有用,因为大部分的关系型数据库都是支持csv,在这里有共同点
mongoexport -d tank -c users -o /home/dev/mongodb/tank/users.dat     #导出整张表
mongoexport -d tank -c users --csv -f uid,name,sex -o tank/users.csv       #导出表中部分字段
mongoexport -d tank -c users -q '{uid:{$gt:1}}' -o tank/users.json      #根据条件敢出数据

6.4 mongoimport导入表 或 表中部分字段

常用命令格式:

1)还原整表导出的非csv文件

mongoimport -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 --upsert --drop 文件名 

重点说一下–upsert,其他参数上面的命令已有提到,–upsert 插入或者更新现有数据

2)还原部分字段的导出文件

mongoimport -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 --upsertFields 字段 --drop 文件名

–upsertFields根–upsert一样

3)还原导出的csv文件

mongoimport -h IP --port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 --type 类型 --headerline --upsert --drop 文件名

上面三种情况,还可以有其他排列组合的。

示例

mongoimport -d tank -c users --upsert tank/users.dat       #还原导出的表数据
mongoimport -d tank -c users  --upsertFields uid,name,sex  tank/users.dat    #部分字段的表数据导入 
mongoimport -d tank -c users --type csv --headerline --file tank/users.csv    #还原csv文件

七、其他常用命令

  • 查看帮助db.help()db.yourCollec.help()db.yourCollec.find().help()
  • 显示当前db状态db.stats(); 当前db版本:db.version(); 查看当前db的链接机器地址:db.getMongo()
  • 查看集合状态db.collection.stats()
  • 修复数据库db.repairDatabase()
  • 复制/克隆数据库db.cloneDatabase("hostname")db.copyDatabase("fromdb", "todb", "hostname")
  • 查询之前的错误信息db.getPrevError(); 清除错误记录: db.resetError()
  • 用户操作
#添加一个用户
db.addUser("name");
db.addUser("userName", "pwd123", true); 添加用户、设置密码、是否只读

#数据库认证、安全模式
db.auth("userName", "123123")
show users                      #显示当前所有用户
db.removeUser("userName")       #删除用户


#添加用户、安全认证
#首先必须使用admin数据库,进行新用户授权;授权成功后,关闭mongo服务
use admin
db.createUser({user:"root",pwd:"123456",roles:[{role:"root",db:"admin"}]})
db.shutdownServer()
#验证:使用use admin通过db.auth(‘root’,‘密码’) 输出1就是验证成功
use admin
db.auth('root','123456')
db.cloneDatabase(127.0.0.1); 将指定机器上的数据库的数据克隆到当前数据库
db.copyDatabase("mydb", "temp", "127.0.0.1");将本机的mydb的数据复制到temp数据库中

八、补充

Navicat操作MongoDB,增删改查的完整代码

use DATABASE_NAME     #如果数据库不存在,则创建数据库,否则切换到指定数据库
show dbs              #查看所有数据库
db.dropDatabase()     #删除当前数据库(默认为test,可通过use db_name切换)


#创建集合
db.createCollection(name[, options])
db.createCollection("runoob")      
db.createCollection("mycol", {capped:true, autoIndexId:true, size:6142800, max:10000})       #创建固定集合 mycol,整个集合空间大小 6142800B, 文档最大个数为 10000个
show collections     show tables     #查看已有集合
#在 MongoDB 中,你不需要创建集合。当你插入一些文档时,MongoDB会自动创建集合
db.mycol2.insert({"name" : "菜鸟教程"})
db.collection.drop()           #删除集合。(use db1,show tb1)


#插入文档
db.COLLECTION_NAME.insert(document)   或 db.COLLECTION_NAME.save(document)
    save():如果_id主键存在则更新数据,如果不存在就插入数据(类似于insert方法)。该方法新版本中(3.2版本之后)已废弃,可以使用db.collection. insertOne()或db.collection.replaceOne()来代替。
	insert(): 若插入的数据主键已经存在,则会抛 org.springframework. dao.DuplicateKeyException 异常,提示主键重复,不保存当前数据。
	
#db.collection.insertOne() 用于向集合插入一个新文档
db.collection.insertOne(
   <document>,
   {
      writeConcern: <document>
   }
)
#db.collection.insertMany() 用于向集合插入一个多个文档
db.collection.insertMany(
   [ <document 1> , <document 2>, ... ],
   {
      writeConcern: <document>,
      ordered: <boolean>
   }
)
#document:要写入的文档;writeConcern:写入策略,默认为 1,即要求确认写操作,0 是不要求;ordered:指定是否按顺序写入,默认 true,按顺序写入。

db.col.insert({title: 'MongoDB 教程', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: '菜鸟教程',
    url: 'http://www.runoob.com',
    tags: ['mongodb', 'database', 'NoSQL'],
    likes: 100
})    或
document=({title: 'MongoDB 教程', 
    description: 'MongoDB 是一个 Nosql 数据库',
    by: '菜鸟教程',
    url: 'http://www.runoob.com',
    tags: ['mongodb', 'database', 'NoSQL'],
    likes: 100
});
db.col.insert(document)


#更新文档
db.collection.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)
	query : update的查询条件,类似sql update查询内where后面的;
	update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的;
	upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
	multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
	writeConcern :可选,抛出异常的级别。

db.col.update({'title':'MongoDB教程'},{$set:{'title':'MongoDB'}})
   #以上语句只会修改第一条发现的文档,如果你要修改多条相同的文档,则需要设置 multi 参数为 true
db.col.update({'title':'MongoDB教程'},{$set:{'title':'MongoDB'}},{multi:true})

#save()方法通过传入的文档来替换已有文档,_id 主键存在就更新,不存在就插入
db.collection.save(
   <document>,
   {
     writeConcern: <document>
   }
)          
#两个参数同update对应参数


#删除文档
db.collection.remove(
   <query>,
   {
     justOne: <boolean>,
     writeConcern: <document>
   }
)
query :(可选)删除的文档的条件;justOne : (可选)如果设为true1,则只删除一个文档,如果不设置该参数,或使用默认值false,则删除所有匹配条件的文档;writeConcern :(可选)抛出异常的级别。
db.users.remove({status:"D"},true)
#删除满足年龄小于20的所有文档
db.users.remove(        
	{ age: { $lt: 20 } },
    { writeConcern: { w: "majority", wtimeout: 5000 } }
)
#删除满足匹配条件的最多一个文档。filter为查询的过滤条件
db.collection.deleteOne(
	<filter>,                   
   	{
    	writeConcern: <document>   #用于控制写入何时应答及超时
    }
)
#删除满足匹配条件的所有文档,语法、参数同deleteOne
db.collection.deleteMany(
	<filter>,                
   	{
    	writeConcern: <document> 
    }
)
#删除所有数据
db.col.remove({})
#MongoDB remove()函数是用来移除集合中的数据。在执行remove()函数前先执行 find()命令来判断执行的条件是否正确,这是一个比较好的习惯。



#查询文档    and,or
db.collection.find(query, projection)
#projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。
#如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,pretty() 方法以格式化的方式来显示所有文档,格式如下:
db.col.find().pretty()    #以易读的方式来读取数据
#findOne() 方法,只返回一个文档
#MongoDB的find()方法可以传入多个键(key),每个键(key)以逗号隔开,即常规SQL 的AND条件。WHERE key1=value1 AND key2=value2
db.col.find({key1:value1, key2:value2}).pretty()
db.col.find(
   {
      $or: [
         {key1: value1}, {key2:value2}
      ]
   }
).pretty()
db.col.find({"likes": {$gt:50}, $or: [{"by": "菜鸟教程"},{"title": "MongoDB 教程"}]}).pretty()            # 类似常规SQL语句为  'where likes>50 AND (by = '菜鸟教程' OR title = 'MongoDB 教程')'
db.member.find({_id :{$gt: 2}, age:18});
db.member.find({_id :{$gt: 2}}).sort({_id:-1});
#返回指定字段,注:_id默认是显示的,只有_id不显示是设置0,其他字段都不可以设置0
find({查询条件,可以空},{显示的字段:1})

MongoDB 与 RDBMS Where 语句比较

操作格式范例RDBMS中的类似语句
等于{<key>:<value>}db.col.find({"by":"菜鸟教程"}).pretty()where by = '菜鸟教程'
小于{<key>:{$lt:<value>}}db.col.find({"likes":{$lt:50}}).pretty()where likes < 50
小于或等于{<key>:{$lte:<value>}}db.col.find({"likes":{$lte:50}}).pretty()where likes <= 50
大于{<key>:{$gt:<value>}}db.col.find({"likes":{$gt:50}}).pretty()where likes > 50
大于或等于{<key>:{$gte:<value>}}db.col.find({"likes":{$gte:50}}).pretty()where likes >= 50
不等于{<key>:{$ne:<value>}}db.col.find({"likes":{$ne:50}}).pretty()where likes != 50

mongo查询操符: e q , eq, eq,ne, i n , in, in,nin, g t , gt, gt,get, l t , lt, lt,lte, a n d , and, and,or, n o t , not, not,nor,$all, e l e M a t c h , eleMatch, eleMatch,size, s l i c e , slice, slice,exists

mongo操作符描述对比mysql
$e等值比较,find({_id :{ $eq: 1}}) 等价于 find({id : 1})id=1
$ne不等于指定值,find({_id:{$ne:1}})id!=1或id<>1
$in数组中包含 ,find( { _id :{ $in: [ 1,2 ] } } )id in (1,2)
$nin数组中不包含,find( { _id :{ $nin: [ 1,2 ] } } )id not in (1,2)
g t , gt, gt,get, l t , lt, lt,lte
$and与(并且)查询,find({$and:[ { _id:{ $gt:1} },{ _id:{ $lt:4} } ]})id>1 and id<4
$or或查询,find({$or:[ { _id:1 },{ _id: 3} ]})id=1 or id=3
$not非查询,非小于3的数据 find({_id :{$not :{ $lt: 3 } } })id>=3
$nor即非查询,find( { $nor: [ { _id: 1 }, { _id: 2 }, { _id: 3 }] } )(id!=1 and id!=2 and id!=3)
$all同时包含,查询tag同时包含3和9的数据,tag是一个数组,find({tag:{$all:[3,9]}}),可查看下面示例
$elemMatch有一个元素匹配即可,find({job:{$elemMatch:{city:‘beijing’,company:‘xiaomi’}}}),可查看下面示例
$size匹配数组大小,find({tag:{$size:3}}),可查看下面示例
$slice返回数组中第几个元素,find({job:{KaTeX parse error: Expected ‘EOF’, got ‘}’ at position 43: …ompany:‘baidu’}}̲},{name:1,job:{slice:1}}),可查看下面示例
$exists匹配是否包含查询字段的文档,find({name:{$exists:true}})
新增:db.集合名称.insert/save/insertOne(文档)
修改:db.集合名称.update(条件,{操作种类:{文档}})
删除:db.集合名称.remove(条件)
#查询所有数据2种写法
db.book.find()
db.getCollection("book").find() 
db.book.find({type:"工具书"})      #条件查询

db.book.remove({type:"工具书"})    #条件删除
db.book.remove({})                #删除所有

#新增数据2种方式   
db.book.save({"name":"springboot"});
db.book.insert({"name":"mango good"});
db.book.save({"name":"springboot",type:"工具书"});
 
#修改"name":"springboot"的数据为"name","springboot2"
# update:遇到满足条件的第一条数据修改;updateOne:修改满足条件的第一条数据;updateMany:修改所有满足条件的
db.book.update({"name":"springboot"},{$set:{"name":"springboot2"}})
db.book.updateOne({"name":"springboot2"},{$set:{"name":"springboot3"}})
db.book.updateMany({"name":"springboot"},{$set:{"name":"springboot2"}})
$type 操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果(Double 1;String 2;Object 3)
db.col.find({"title" : {$type : 2}})     或
db.col.find({"title" : {$type : 'string'}})

limit(number) 在MongoDB中读取指定数量的数据记录
db.COLLECTION_NAME.find().limit(NUMBER)
skip(number) 跳过指定数量的数据,默认参数为0
db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)
db.col.find({},{"title":1,_id:0}).limit(1).skip(1) //显示第二条数据


使用sort()方法对数据进行排序,sort()方法可以通过参数指定排序的字段,并使用1-1来指定排序的方式,其中1为升序排列,而-1是用于降序排列.
db.COLLECTION_NAME.find().sort({KEY:1})
skip(), limilt(), sort()三个放在一起执行的时候,执行的顺序是先sort(), 然后是skip(),最后是显示的limit()

扫描全集合的查询效率是非常低,索引通常能够极大的提高查询的效率。索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构。
db.collection.createIndex(keys, options)      //创建索引,Key值为你要创建的索引字段,1为指定按升序创建索引,如果你想按降序来创建索引指定为-1即可
db.col.createIndex({"title":1,"description":-1})  //多字段创建索引
db.col.getIndexes()    //查看集合索引
db.col.totalIndexSize()   //查看集合索引大小
db.col.dropIndexes()      //删除集合所有索引
db.col.dropIndex("索引名称")    //删除集合指定索引

聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果。有点类似 SQL 语句中的 count(*)。$sum,$avg,$min/max,$push,$addToSet,$first/last
db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)
 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : 1}}}])        类似于sql语句
select by_user, count(*) from mycol group by by_user
 
MongoDB复制是将数据同步在多个服务器的过程.
MongoDB备份(mongodump,可以导出所有数据到指定目录中)与恢复(mongorestore,恢复备份的数据)
mongodump -h dbhost -d dbname -o dbdirectory
-o:备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据
mongorestore -h <hostname><:port> -d dbname <path>
<path>:mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。你不能同时指定 <path>--dir 选项,--dir也可以设置备份目录。

mongostat和mongotop 两个命令来监控MongoDB的运行情况。
mongostat是mongodb自带的状态检测工具,在命令行下使用(安装目录下的bin目录 输入mongostat)。它会间隔固定时间获取mongodb的当前运行状态,并输出。
mongotop也是mongodb下的一个内置工具,mongotop提供了一个方法,用来跟踪一个MongoDB的实例,查看哪些大量的时间花费在读取和写入数据。 mongotop提供每个集合的水平的统计数据。默认情况下,mongotop返回值的每一秒。(用法同mongostat)
mongotop number  //<sleeptime>参数,可不使用,等待的时间长度,以秒为单位
MongoDB关系: 1:1,1:N,N:1,N:N
嵌入式方法/关系
引用式方法/关系:把用户数据文档和用户地址数据文档分开,通过引用文档的 id 字段来建立关系

参考 MongoDB常用命令详细讲解(最全)、Mongo基本命令

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/803185.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS 开发者联盟高级认证最新题库

本篇文章包含 Next 版本更新后高级认证题库中95%的题目。 答案正确率 50-60%&#xff0c;答案仅做参考。 请在考试前重点看一遍题目&#xff0c;勿要盲目抄答案。 欢迎在评论留言正确答案和未整理的题目。 1、下面关于方舟字节码格式PREF_IMM16_v8_v8描述正确的是 16位前缀操作…

STM32 BootLoader 刷新项目 (三) 程序框架搭建及刷新演示

STM32 Customer BootLoader 刷新项目 (三) 程序框架搭建 文章目录 STM32 Customer BootLoader 刷新项目 (三) 程序框架搭建典型工作流程 1. 硬件原理图介绍1.1 USART硬件介绍1.2 LED和按键介绍 2. STM32 CubeMX工程搭建2.1 创建工程2.2 系统配置2.3 USART串口配置2.4 配置按键G…

汇总国内镜像提供了Redis的下载地址

文章目录 1. 清华大学开源软件镜像站&#xff1a;2. 中国科技大学开源软件镜像&#xff1a;3. 阿里云镜像&#xff1a;4. 华为云镜像&#xff1a;5. 腾讯云镜像&#xff1a;6. 网易开源镜像站7. 官方GitHub仓库&#xff08;虽然不是镜像&#xff0c;但也是一个可靠的下载源&…

java学习笔记(浓缩版)

一.数据类型 整型&#xff08;4个&#xff09;&#xff1a; byte&#xff08;字节型&#xff09;、short&#xff08;短整型&#xff09;、int&#xff08;整型&#xff09;、long&#xff08;长整型&#xff09; 浮点型&#xff08;2个&#xff09;&#xff1a;float&#x…

彻底改变时尚:使用 GAN 实现 AI 的未来

彻底改变时尚&#xff1a;使用 GAN 实现 AI 的未来 一、介绍 想象一下&#xff0c;在这个世界里&#xff0c;时装设计师永远不会用完新想法&#xff0c;我们穿的每一件衣服都是一件艺术品。听起来很有趣&#xff0c;对吧&#xff1f;好吧&#xff0c;我们可以在通用对抗网络 &a…

Postman安装使用教程(详解)

目录 一、Postman是什么 二、安装系统要求 三、下载Postman 四、注册和登录Postman 五、创建工作空间 六、创建请求 一、Postman是什么 在安装之前&#xff0c;让我们先来简单了解一下Postman。Postman是一个流行的API开发工具&#xff0c;它提供了友好的用户界面用于发送…

Python 实现股票指标计算——WR

WR - 威廉指标 1 公式 威廉指标的计算公式为&#xff1a; 其中&#xff1a; &#x1d43b;&#x1d45b;​ 是过去n日内的最高价。 &#x1d43f;&#x1d45b;​ 是过去n日内的最低价。 &#x1d436; 是当前收盘价。 2 数据准备 我们以科创50指数 000688 为例&#xff0c…

如何打造一个专属网盘?可道云teamOS这些个性化设置了解一下

在这个数字化时代&#xff0c;企业对于云端存储和协作工具的需求日益增长。而网盘作为企业协作的重要工具之一&#xff0c;其个性化、定制化的需求也日益凸显。 今天&#xff0c;我要为大家介绍的是一款高度个性化的企业网盘——可道云teamOS。 满足个性化需求的企业网盘 可…

连锁直营店小程序赋能多店如何管理

如商超便利店卖货线下场景&#xff0c;也有不少品牌以同城多店和多地开店经营为主&#xff0c;获取店铺周围客户和散流&#xff0c;如今线上重要性凸显&#xff0c;品牌电商发展是经营的重要方式之一&#xff0c;也是完善同城和外地客户随时便捷消费的方式之一。 多个门店管理…

ESP8266模块简单连接以及作为作为Station连接“服务器”的问题(ERROR CLOSED)

ESP8266简介 AT指令集是从终端设备&#xff08;Terminal Equipment&#xff0c;TE)或数据终端设备&#xff08;Data Terminal Equipment&#xff0c;DTE)向终端适配器(Terminal Adapter&#xff0c;TA)或数据电路终端设备(Data CircuitTerminal Equipment&#xff0c;DCE)发送…

[米联客-安路飞龙DR1-FPSOC] FPGA基础篇连载-17 I2C通信协议原理

软件版本&#xff1a;Anlogic -TD5.9.1-DR1_ES1.1 操作系统&#xff1a;WIN10 64bit 硬件平台&#xff1a;适用安路(Anlogic)FPGA 实验平台&#xff1a;米联客-MLK-L1-CZ06-DR1M90G开发板 板卡获取平台&#xff1a;https://milianke.tmall.com/ 登录“米联客”FPGA社区 ht…

GB35114国密算法-GMSSL

C有个三方库-GMSSL是可以进行GB35114所需要的SM2、SM3、SM4等加解密算法的&#xff0c;但是使用国密算法是需要申请报备的 GmSSL是由北京大学自主开发的国产商用密码开源库&#xff0c;实现了对国密算法、标准和安全通信协议的全面功能覆盖&#xff0c;支持包括移动端在内的主流…

gemini-pro-vision 看图说话

一、安装 pip install -U langchain-google-vertexai 二、设置访问权限 申请服务账号json格式key 三、完整代码 import gradio as gr import json import base64 from pathlib import Path import os import time import requests from fastapi import FastAPI, UploadFile,…

北京青蓝智慧科技:如何查询“工信部教育考试中心”颁发的证书

查验专业技术人员职业资格证书的途径共有四种&#xff1a; 首先&#xff0c;可以通过登录中国人事考试网的全国专业技术人员职业资格证书查询验证系统进行查验。 其次&#xff0c;利用手机微信公众号扫描证书上的二维码也能实现信息验证。 第三&#xff0c;登陆全国人社政务服…

打包一个自己的Vivado IP核

写在前面 模块复用是逻辑设计人员必须掌握的一个基本功&#xff0c;通过将成熟模块打包成IP核&#xff0c;可实现重复利用&#xff0c;避免重复造轮子&#xff0c;大幅提高我们的开发效率。 接下来将之前设计的串口接收模块和串口发送模块打包成IP核&#xff0c;再分别调用…

3.5、matlab打开显示保存点云文件(.ply/.pcd)以及经典点云模型数据

1、点云数据简介 点云数据是三维空间中由大量二维点坐标组成的数据集合。每个点代表空间中的一个坐标点&#xff0c;可以包含有关该点的颜色、法向量、强度值等额外信息。点云数据可以通过激光扫描、结构光扫描、摄像机捕捉等方式获取&#xff0c;广泛应用于计算机视觉、机器人…

STM32智能交通监测系统教程

目录 引言环境准备智能交通监测系统基础代码实现&#xff1a;实现智能交通监测系统 4.1 数据采集模块 4.2 数据处理与控制模块 4.3 通信与网络系统实现 4.4 用户界面与数据可视化应用场景&#xff1a;交通监测与管理问题解决方案与优化收尾与总结 1. 引言 智能交通监测系统通…

新手教学系列——高效管理MongoDB数据:批量插入与更新的实战技巧

前言 在日常开发中,MongoDB作为一种灵活高效的NoSQL数据库,深受开发者喜爱。然而,如何高效地进行数据的批量插入和更新,却常常让人头疼。今天,我们将一起探讨如何使用MongoDB的bulk_write方法,简化我们的数据管理流程,让代码更加简洁高效。 常规做法:find、insertone…

mysql的索引事务和存储引擎

一、索引 1、索引 索引的概念 &#xff1a;索引是一个排序的列表&#xff0c;在列表当中存储索引的值以及索引值对应数据所在的物理行。 索引的引用&#xff1a; 使用索引之后&#xff0c;就不需要扫描全表来定位某行的数据。 加快数据库的查询速度。 索引可以是表中的一…

Python教授耗费13年总结的400页《Python工匠》手册

Python 能干的事情实在太多了&#xff0c;掰着指头数有点不够用。 Web 开发、数据分析、网络爬虫、自动化运维、后台开发、机器学习....... 如果你知道主攻哪个方向&#xff0c;只需重点去学习。不过&#xff0c;不论哪个方向&#xff0c;Python 编程的核心知识都是需要掌握的…