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 数据库。直接复制粘贴使用即可!

相关推荐
施嘉伟19 分钟前
一次典型的 SQL 性能问题排查:临时表导致的隐藏性能陷阱
数据库·sql
鋆雨无欢丶21 分钟前
docker证书认证问题
运维·docker·容器
阿杰 AJie22 分钟前
Docker 容器启动的全方位方法汇总
运维·docker·容器
IT 乔峰28 分钟前
分享一个负载均衡的NDB高可用集群架构+部署详细说明
数据库·架构·负载均衡
丁丁点灯o29 分钟前
oracle中基于正则表达式匹配规则提取子串的函数REGEXP_SUBSTR
数据库·oracle·正则表达式
木风小助理30 分钟前
Android 数据库实操指南:从 SQLite 到 Realm,不同场景精准匹配
jvm·数据库·oracle
我的golang之路果然有问题33 分钟前
Docker 之常用操作(实习中的)
java·运维·笔记·docker·容器·eureka
Elseide艾思33 分钟前
数字经济专利数据库(1994年更新至今)
数据库
Stark-C36 分钟前
密码管理器的尽头,是自托管!极空间私有化部署『password-XL』
docker
optimistic_chen37 分钟前
【Redis系列】事务特性
数据库·redis·笔记·缓存·事务