mongodb基础操作

创建数据库

bash 复制代码
use admin

授权

bash 复制代码
db.auth("admin","123456")

创建用户

bash 复制代码
db.createUser({
user: "xxx",
pwd: "xxxxxx",
roles: [
{ role: "readWrite", db: "iot" }
]
})

查询数据库大小

bash 复制代码
show dbs;

查询结果数量

bash 复制代码
db.mon.find().count()

删除数据库

bash 复制代码
db.dropdatabase()

查询一条,查看表结构

bash 复制代码
#查询表结构,其中mon为 colnettions名称
db.mon.findone()

查询数据

bash 复制代码
#查找数据,其中skip表示第几条开始,limit表示查看指定数量的结果
db.mon.find().skip(2).limit(4)

创建集合

bash 复制代码
#创建集合
iiot> db.createCollection("mon")
{ ok: 1 }

删除集合

bash 复制代码
#删除集合
iiot> db.mon.drop()
true

插入数据

bash 复制代码
#插入数据
db.mon.insert({"name":"张三","age":"18"})
db.mon.insert({"name":"李四","age":"19"})
db.mon.insert({"name":"王五","age":"20"})

查询数据库数据

bash 复制代码
#查询所有数据,等同于select * from mon;
iiot> db.mon.find() 
[
  { _id: ObjectId('673d4613a40aa131622202d8'), name: '张三', age: '18' },
  { _id: ObjectId('673d466aa40aa131622202d9'), name: '李四', age: '19' },
  { _id: ObjectId('673d466ca40aa131622202da'), name: '王五', age: '20' }
]

根据条件查询数据

bash 复制代码
#查询单条数据,等同于select * from mon where age = 19;
iiot> db.mon.find({"age" : "19"})
[
  { _id: ObjectId('673d466aa40aa131622202d9'), name: '李四', age: '19' }
]

根据条件范围查询数据

bash 复制代码
#查询单条数据,等同于select * from mon where age < 20;
iiot> db.mon.find({"age":{"$lt":"20"}})
[
  { _id: ObjectId('673d4613a40aa131622202d8'), name: '张三', age: '18' },
  { _id: ObjectId('673d466aa40aa131622202d9'), name: '李四', age: '19' }
]

删除数据

bash 复制代码
#删除单条第一个匹配到的文档数据
iiot> db.mon.deleteOne({"age":"18"})
{ acknowledged: true, deletedCount: 1 }

#删除多条匹配到的文档数据
iiot> db.mon.deleteMany({"age":"18"})
{ acknowledged: true, deletedCount: 2 }

#删除集合中文档数据
iiot> db.mon.remove({})
{ acknowledged: true, deletedCount: 9613647 }

#删除集合及所有文档数据
iiot> db.mon.drop({})

索引操作

bash 复制代码
#查看索引的大小
iiot> db.mon.totalIndexSize()
378810368

#创建索引
db.mon.createIndex({"expireAt":-1},{expireAfterSeconds:30});
db.mon.createIndex({deviceCode:1});

#删除索引
iot> db.mon.dropIndexes()
{
  nIndexesWas: 4,
  msg: 'non-_id indexes dropped for collection',
  ok: 1
}

备份数据库

bash 复制代码
#mongodump是MongoDB官方提供的备份工具,它可以从MongoDB数据库读取数据,并生成BSON文件,mongodump适合用于备份和恢复数#据量较小的MongoDB数据库, 不适用于大数据量备份
#默认情况下mongodump不获取local数据库里面的内容。mongodump仅备份数据库中的文档,不备份索引,所以我们还原后,需要重新生成索引。 mongodump备份过程中会对mongod服务的性能产生影响,我们建议在业务低峰期进行操作。如果我们备份的数据,大于系统内存,我们备份的时候容易出现错误
mongodump --host 127.0.0.1 -d iot -uxxx -pxxxxxx -o /backup --gzip
mongodump -d iot -uxxx -pxxxxxx -o /backup --gzip

/dump/iot/xxx_logs.bson  
/dump/iot/xxx_logs.metadata.json  
#拷贝
xxx_logs.bson和xxx_logs.metadata.json 至还原服务器
/dump/iot/iot.bson  
/dump/iot/iot.metadata.json

#说明
--host:指定ip和端口
-u:用户
-p:密码
-c: 指定集合名称
-d:指定备份的库名
-o: 备份输出到哪个目录
--gzip:从压缩文件中进行恢复
--drop:恢复数据之前删除原来数据库数据,避免数据重复

还原数据库

bash 复制代码
#还原数据库,仅使用bson.gz即可,删除原索引
mongorestore --host 127.0.0.1:27017 -uxxx -pxxxxxx -d xxx -c xxx /backup/iot/xxx.bson.gz --gzip --drop
#说明
--host:指定ip和端口
-u:用户
-p:密码
-d:指定恢复的库名
--dir: 指定恢复目录
--gzip:压缩备份文件
相关推荐
云和数据.ChenGuang1 小时前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
woshilys2 小时前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi2 小时前
SQL注入的那些面试题总结
数据库·sql
建投数据3 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi4 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀4 小时前
Redis梳理
数据库·redis·缓存
独行soc4 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天4 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺5 小时前
分布式系统架构:服务容错
数据库·架构
独行soc6 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘