MongoDB 常用操作指南(Docker 环境下)

本文详细介绍如何在 Docker 中操作 MongoDB,包括如何进入命令行、进行用户认证、查看数据库和集合,以及常用的索引操作和其他高频使用的 MongoDB 方法。小白也能轻松上手


1. 在 Docker 中进入 MongoDB 命令行

  1. 进入运行 MongoDB 容器的命令行:

    bash 复制代码
    docker exec -it <容器名称或ID> mongo

    例如:

    bash 复制代码
    docker exec -it mongodb_container mongo
  2. 切换到管理员数据库 admin

    javascript 复制代码
    use admin
  3. 用户认证:

    javascript 复制代码
    db.auth("aidenmx", "qazx123")
    db.auth("aiden", "qazx123")

    提示 :这里假设您的用户名为 aidenmxaiden,密码为 qazx123。根据实际情况替换。通常只需一次认证。


2. 查看数据库和集合

  1. 显示所有数据库:

    javascript 复制代码
    show dbs
  2. 切换到某个数据库:

    javascript 复制代码
    use history
  3. 显示当前数据库的所有集合(表):

    javascript 复制代码
    show tables

3. 查看集合中的索引

查看指定集合中的索引信息:

javascript 复制代码
db.<集合名>.getIndexes()

例如:

javascript 复制代码
db.sublist2.getIndexes()

输出会显示所有索引的详细信息,包括索引字段和索引类型。


4. 创建索引

4.1 创建单字段索引

为某个字段创建索引:

javascript 复制代码
db.<集合名>.createIndex({ <字段名>: 1 })
  • 1 表示升序索引,-1 表示降序索引。

例如:

javascript 复制代码
db.sublist2.createIndex({ applicationNumber: 1 })

4.2 创建复合索引

为多个字段创建复合索引:

javascript 复制代码
db.<集合名>.createIndex({ <字段1>: 1, <字段2>: -1 })
  • 注意字段顺序,前缀规则适用。

例如:

javascript 复制代码
db.sublist2.createIndex({ applicationNumber: 1, classNumber: -1 })

5. 删除索引

  1. 删除单个索引:

    javascript 复制代码
    db.<集合名>.dropIndex("<索引名>")

    获取索引名可通过 getIndexes() 查看。

  2. 删除集合中的所有索引:

    javascript 复制代码
    db.<集合名>.dropIndexes()

6. 查询相关操作

  1. 查询所有文档:

    javascript 复制代码
    db.<集合名>.find()
  2. 查询第一个文档:

    javascript 复制代码
    db.<集合名>.findOne()
  3. 条件查询:

    javascript 复制代码
    db.<集合名>.find({ <字段名>: <值> })

    例如:

    javascript 复制代码
    db.sublist2.find({ applicationNumber: "123456" })
  4. 限制返回条数:

    javascript 复制代码
    db.<集合名>.find().limit(10)
  5. 排序查询:

    javascript 复制代码
    db.<集合名>.find().sort({ <字段名>: 1 })
    • 1 表示升序,-1 表示降序。

7. 插入与删除操作

  1. 插入单个文档:

    javascript 复制代码
    db.<集合名>.insertOne({ <字段1>: <值1>, <字段2>: <值2> })

    例如:

    javascript 复制代码
    db.sublist2.insertOne({ applicationNumber: "123456", classNumber: 5 })
  2. 删除符合条件的文档:

    javascript 复制代码
    db.<集合名>.deleteOne({ <字段名>: <值> })

    例如:

    javascript 复制代码
    db.sublist2.deleteOne({ applicationNumber: "123456" })
  3. 删除所有文档:

    javascript 复制代码
    db.<集合名>.deleteMany({})

8. 更新操作

  1. 更新单个文档:

    javascript 复制代码
    db.<集合名>.updateOne(
        { <匹配条件> },
        { $set: { <字段1>: <新值1>, <字段2>: <新值2> } }
    )

    例如:

    javascript 复制代码
    db.sublist2.updateOne(
        { applicationNumber: "123456" },
        { $set: { classNumber: 10 } }
    )
  2. 更新多个文档:

    javascript 复制代码
    db.<集合名>.updateMany(
        { <匹配条件> },
        { $set: { <字段1>: <新值1>, <字段2>: <新值2> } }
    )

9. 数据统计

  1. 查看集合中文档数量:

    javascript 复制代码
    db.<集合名>.countDocuments()
  2. 按条件统计文档数量:

    javascript 复制代码
    db.<集合名>.countDocuments({ <字段名>: <值> })

    例如:

    javascript 复制代码
    db.sublist2.countDocuments({ classNumber: 5 })

通过上述命令,您可以高效地操作 MongoDB 数据库。直接复制粘贴使用即可!

相关推荐
qianshang2334 小时前
SQL注入学习总结
网络·数据库·渗透
what丶k4 小时前
深入解析Redis数据持久化:RBD机制原理、实操与生产最佳实践
数据库·redis·缓存
瀚高PG实验室5 小时前
通过数据库日志获取数据库中的慢SQL
数据库·sql·瀚高数据库
Hgfdsaqwr5 小时前
Python在2024年的主要趋势与发展方向
jvm·数据库·python
invicinble5 小时前
对于Mysql深入理解
数据库·mysql
阳光九叶草LXGZXJ6 小时前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
Hgfdsaqwr6 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
lightningyang6 小时前
DVWA 在 openEuler 系统的安装部署
docker·渗透测试·openeuler·dvwa·天枢一体化虚拟仿真靶场平台
s1hiyu6 小时前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python
2301_763472466 小时前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python