mongodb基本命令实例小结

(编辑:jimmy 日期: 2024/12/24 浏览:2)

本文实例讲述了mongodb基本命令。分享给大家供大家参考,具体如下:

1 切换数据库

use admin;

2 查看当前数据库

db;

2.1 查看所有数据库

show dbs;

3 查看当前数据库下面的表

show collections;

4 删除数据库

use test;
db.dropDatabase(); #删除当前数据库
show dbs;  #验证删除结果

5 删除集合或者表

db.table_name.drop(); #删除表 table_name

6 查看账号信息

mongo --port=23000
use admin;
db.auth('username','password')
db.system.users.find().pretty()  #查看所有账号信息
show users; #查看当前账号信息
db.getUser('username') #查看指定用户的信息

7 使用gzip压缩的方式备份与恢复,注意只要换个命令就行,后面的不变,这里没用设置用户名和密码

mongodump  --port=23000 --archive=/data/mongo_backup/testdb-2.20191203.gz --db testdb-2 --gzip
mongorestore --port=23000 --archive=/data/mongo_backup/testdb-2.20191203.gz --db testdb-2 --gzip
** 这种备份方式生成一个gzip文件,解压后也是一个文件,将所有内容都放到一个文件里面

8 不压缩的方式备份

mongodump --port=23000 --db=testdb-2 -o /data/mongo_backup/20191203
mongorestore --port=23000 --db=testdb-2 --drop /data/mongo_backup/20191203/testdb-2
**经过这种方式备份,每个表通常就两个文件:.bson和.metadata.json

9 在shell中使用mongo命令查询

# 使用eval mongo ip:port/database --eval ""
[root@localhost ~]# mongo localhost:23000/testdb-2 --eval "printjson(db.table1.findOne())"
MongoDB shell version v3.6.13
connecting to: mongodb://localhost:23000/testdb-2"id" : UUID("e87ef5ae-a6b7-47d6-a91c-65f3a0b81ac0") }
MongoDB server version: 3.6.13
{
  "_id" : ObjectId("5de60a767321940034390f16"),
  "id" : 129,
  "name" : "hehe"
}
#使用--quiet 去掉不必要的信息
[root@localhost ~]# mongo localhost:23000/testdb-2 --quiet --eval "printjson(db.table2.findOne())"
{ "_id" : ObjectId("5de615b8eac07a724c6911b6"), "id" : 6, "name" : "hehe" }

#删除表
[root@localhost ~]# mongo localhost:23000/testdb-2 --eval "db.table1.drop();"
MongoDB shell version v3.6.13
connecting to: mongodb://localhost:23000/testdb-2"id" : UUID("0cf5b11f-c6ef-417c-8bbd-a2f8414f589c") }
MongoDB server version: 3.6.13
true

10 shell脚本中使用mongo命令

#!/bin/bash
mongo localhost:23000/testdb-2 <<EOF
 var cursor=db.table2.find();
 while (cursor.hasNext()){
  var item = cursor.next();
  print(item.name);

 }
EOF

#传参的方式
#!/bin/bash
table_name=$1
mongo localhost:23000/testdb-2 <<EOF
var cursor=db.${table_name}.find();
while (cursor.hasNext()){
var item = cursor.next();
print(item.name);

}
EOF

希望本文所述对大家MongoDB数据库程序设计有所帮助。

一句话新闻

一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?