mongodb nosql数据库笔记

MongoDB 简介

MongoDB 是一个开源的 NoSQL 数据库,采用文档存储模型(BSON 格式,类似 JSON),支持高灵活性、水平扩展和高性能的数据操作。与传统关系型数据库(如 MySQL)不同,MongoDB 无需预定义表结构,适合处理半结构化或非结构化数据。


MongoDB 核心特性

文档模型

数据以文档形式存储,每个文档包含键值对,嵌套结构支持复杂数据类型。示例文档:

json 复制代码
{
  "_id": ObjectId("507f191e810c19729de860ea"),
  "name": "Alice",
  "age": 30,
  "address": {
    "city": "New York",
    "zip": "10001"
  }
}

高性能

支持索引、聚合管道和内存映射文件,读写速度快。

javascript 复制代码
// 创建索引
db.users.createIndex({ name: 1 });

水平扩展(分片)

通过分片(Sharding)将数据分布到多个服务器,支持海量数据存储。

高可用性

副本集(Replica Set)提供自动故障转移和数据冗余。


基础操作

插入数据

javascript 复制代码
db.users.insertOne({
  name: "Bob",
  age: 25,
  hobbies: ["reading", "hiking"]
});

查询数据

javascript 复制代码
// 查找所有年龄大于 20 的用户
db.users.find({ age: { $gt: 20 } });

// 使用聚合管道分组统计
db.users.aggregate([
  { $group: { _id: "$city", count: { $sum: 1 } } }
]);

更新数据

javascript 复制代码
db.users.updateOne(
  { name: "Bob" },
  { $set: { age: 26 } }
);

删除数据

javascript 复制代码
db.users.deleteOne({ name: "Alice" });

适用场景

  1. 实时分析:快速处理日志、传感器数据等时序数据。
  2. 内容管理:灵活存储文章、评论等嵌套内容。
  3. 物联网(IoT):高效存储设备生成的异构数据。
  4. 移动应用:支持离线同步和灵活的数据模型变更。

不适用场景

  1. 复杂事务:需跨文档强一致性时(尽管 MongoDB 4.0+ 支持多文档事务,但性能受限)。
  2. 高度结构化数据:固定表结构且关系复杂的场景(如财务系统)。

安装与工具

  1. 官方下载 :从 MongoDB官网 获取社区版。
  2. 命令行工具mongosh(MongoDB Shell)。
  3. GUI工具:MongoDB Compass、Robo 3T。

性能优化建议

  1. 合理设计索引,避免全表扫描。
  2. 使用投影(Projection)限制返回字段。
  3. 分片键选择需均匀分布数据。
  4. 监控慢查询日志(db.setProfilingLevel(2))。
javascript 复制代码
// 查看慢查询
db.system.profile.find().sort({ millis: -1 }).limit(10);
相关推荐
小智RE0-走在路上13 分钟前
Python学习笔记(7)--集合,字典,数据容器总结
笔记·python·学习
map_vis_3d1 小时前
JSAPIThree 加载单体三维模型学习笔记:SimpleModel 简易加载方式
笔记·学习·3d
Lv11770083 小时前
Visual Studio 中的密封类和静态类
ide·笔记·c#·visual studio
EniacCheng5 小时前
【RUST】学习笔记-整型
笔记·学习·rust
断剑zou天涯5 小时前
【算法笔记】树状数组IndexTree
java·笔记·算法
北岛寒沫6 小时前
北京大学国家发展研究院 经济学辅修 经济学原理课程笔记(第九课 公共产品与公共资源)
经验分享·笔记
Vizio<6 小时前
STM32HAL库开发笔记-STM32CubeMX点灯
笔记·stm32·嵌入式硬件
找方案6 小时前
hello-agents 学习笔记:智能体发展史 —— 从符号逻辑到 AI 协作的进化之旅
人工智能·笔记·学习·智能体·hello-agents
蒙奇D索大6 小时前
【数据结构】考研408 | 平方探测法精讲:跳跃探查的艺术与聚集迷思
数据结构·笔记·考研·改行学it
代码游侠6 小时前
应用——Linux进程通信与信号处理
linux·运维·服务器·笔记·学习·信号处理