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

相关推荐
wyiyiyi3 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任4 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
xiep14383335106 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
敲上瘾6 小时前
Linux系统cgroups资源精细化控制基础
linux·测试工具·docker·压力测试·cgroups
Java小白程序员7 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
老虎06277 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle
伊成9 小时前
Docker 部署 Nginx 完整指南
nginx·docker·容器
爱掘金的土拨鼠9 小时前
国产化dm数据库锁表解锁
数据库
落日漫游9 小时前
K8s核心组件全解析
运维·docker·运维开发
庖丁解java10 小时前
N个Utils
数据库