MongoDB入门实战:从零开始掌握文档数据库操作

文章目录


一、环境准备与基础操作

1. 进入/创建数据库

use my_test // 进入/创建名为my_test的数据库

2. 插入首个文档

db.user.insert({ username: "sunwukong" }) // 创建user集合并插入第一条数据

3. 基础查询

c 复制代码
db.user.find()  // 查看集合所有文档
db.user.find().count()  // 统计文档总数

二、文档更新操作秘籍

1. 字段操作

c 复制代码
// 添加新字段
db.user.update(
  { username: "sunwukong" },
  { $set: { address: "huaguoshan" } }
)

// 删除指定字段
db.user.update(
  { username: "sunwukong" },
  { $unset: { address: 1 } }
)

2. 文档替换

c 复制代码
db.user.update(
  { username: "zhubajie" },
  { username: "tangseng" }  // 完全替换原文档
)

三、数组操作黑科技

1. 嵌套文档创建

c 复制代码
// 创建包含数组的嵌套文档
db.user.update(
  { username: "sunwukong" },
  { $set: { 
    hobby: {
      cities: ["beijing", "shanghai"],
      movies: ["sanguo", "hero"]
    }
  }}
)

2. 数组元素操作

c 复制代码
// 添加新元素(允许重复)
db.user.update(
  { username: "tangseng" },
  { $push: { "hobby.movies": "Interstellar" } }
)

// 智能去重添加
db.user.update(
  { username: "tangseng" },
  { $addToSet: { "hobby.movies": "Interstellar" } }
)

// 精准删除元素,$pull删除数组中所有满足指定条件的元素
db.user.update(
  { username: "tangseng" },
  { $pull: { "hobby.movies": "Interstellar" } }
)
// 使用 $pullAll 删除多个指定值,删除数组中所有匹配给定值的元素。
db.user.update({username:"tangseng" },
{ $pullAll: {"hobby.movies": ["Interstellar","King of comedy"] } });
// 使用 $pop 删除首尾元素。功能:删除数组的第一个或最后一个元素。 1: 删除最后一个元素,-1: 删除第一个元素
db.user.update({username:"tangseng" },
{ $pop: {"hobby.movies": -1 } })

四、高级删除技巧

1. 条件删除文档

db.user.remove({ "hobby.cities": "beijing" }) // 删除包含指定数组元素的文档

集合级操作

db.user.drop() // 慎用!删除整个集合

五、实战技巧总结

操作类型 常用命令 特点说明
插入操作 insert 自动创建集合
查询操作 find+count 支持条件过滤
更新操作 update+$set/$unset 精确字段控制
数组操作 $push/$addToSet/$pull 支持嵌套结构操作
删除操作 remove+条件 / drop 区分文档级和集合级删除

总结

通过掌握这些核心操作,您已经可以完成MongoDB约80%的日常开发需求。接下来可以深入探索聚合管道、索引优化等高级特性,进一步提升数据库操作效率。

相关推荐
XXX-X-XXJ1 小时前
Django 用户认证流程详解:从原理到实现
数据库·后端·python·django·sqlite
my一阁5 小时前
2025-web集群-问题总结
前端·arm开发·数据库·nginx·负载均衡·web
JIngJaneIL7 小时前
篮球论坛|基于SprinBoot+vue的篮球论坛系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·篮球论坛系统
一只叫煤球的猫9 小时前
MySQL 索引的 “最左前缀原则”,用查字典的例子讲透
数据库·mysql·性能优化
一只小bit10 小时前
MySQL常用内置函数整理:提高你的查询效率
数据库·mysql·数据完整性·表约束
chxii11 小时前
ISO 8601日期时间标准及其在JavaScript、SQLite与MySQL中的应用解析
开发语言·javascript·数据库
小丁爱养花13 小时前
Redis 内部编码/单线程模型/string
数据库·redis·缓存·1024程序员节
l1t13 小时前
利用DuckDB SQL求解集合数学题
数据库·sql·算法·集合·duckdb