当前位置: 首页 > article >正文

【自学笔记】MongoDB基础知识点总览-持续更新

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • MongoDB基础知识点总览
    • 目录
    • 1. MongoDB简介
      • 示例代码:连接MongoDB
    • 2. 安装与配置
      • 安装MongoDB
      • 配置MongoDB
    • 3. 基本概念
      • 示例代码:创建数据库和集合
    • 4. CRUD操作
      • 插入文档(Create)
      • 读取文档(Read)
      • 更新文档(Update)
      • 删除文档(Delete)
    • 5. 索引
      • 示例代码:创建索引
    • 6. 聚合管道
      • 示例代码:使用聚合管道
    • 7. 复制与分片
      • 复制
      • 分片
  • 总结


MongoDB基础知识点总览

目录

  1. MongoDB简介
  2. 安装与配置
  3. 基本概念
  4. CRUD操作
  5. 索引
  6. 聚合管道
  7. 复制与分片

1. MongoDB简介

MongoDB是一个面向文档的NoSQL数据库,它使用JSON风格的文档来存储数据。它提供了高性能、高可用性和可扩展性。

示例代码:连接MongoDB

const { MongoClient } = require('mongodb');

const uri = "your_mongodb_uri";
const client = new MongoClient(uri, { useNewUrlParser: true, useUnifiedTopology: true });

async function run() {
    try {
        await client.connect();
        console.log("Connected successfully to server");
        const database = client.db('your_database_name');
        console.log("Connected correctly to database");
    } finally {
        await client.close();
    }
}

run().catch(console.dir);

2. 安装与配置

安装MongoDB

  • 在Linux上安装:使用包管理器(如aptyum)。
  • 在Windows上安装:从MongoDB官网下载并安装。
  • 在macOS上安装:使用Homebrew。

配置MongoDB

  • 配置文件路径:/etc/mongod.conf(Linux),mongod.cfg(Windows)。
  • 启动MongoDB服务:sudo systemctl start mongod(Linux),mongod --config <path_to_config>(手动)。

3. 基本概念

  • 文档(Document):MongoDB中的基本数据单元,类似于JSON对象。
  • 集合(Collection):一组文档的集合。
  • 数据库(Database):一个或多个集合的集合。

示例代码:创建数据库和集合

const { MongoClient } = require('mongodb');

const uri = "your_mongodb_uri";
const client = new MongoClient(uri, { useNewUrlParser: true, useUnifiedTopology: true });

async function run() {
    try {
        await client.connect();
        const database = client.db('test_database');
        await database.createCollection('test_collection');
        console.log("Database and collection created");
    } finally {
        await client.close();
    }
}

run().catch(console.dir);

4. CRUD操作

插入文档(Create)

const document = { name: "Alice", age: 25, city: "New York" };
const result = await collection.insertOne(document);
console.log(`${result.insertedId} document inserted`);

读取文档(Read)

const documents = await collection.find({}).toArray();
console.log(documents);

更新文档(Update)

const filter = { name: "Alice" };
const update = { $set: { age: 26 } };
const result = await collection.updateOne(filter, update);
console.log(`${result.modifiedCount} document updated`);

删除文档(Delete)

const filter = { name: "Alice" };
const result = await collection.deleteOne(filter);
console.log(`${result.deletedCount} document deleted`);

5. 索引

索引用于提高查询性能。MongoDB支持多种类型的索引,包括单字段索引、复合索引、唯一索引等。

示例代码:创建索引

await collection.createIndex({ name: 1 }); // 1表示升序,-1表示降序

6. 聚合管道

聚合管道提供了对集合中的文档进行转换和聚合的功能。

示例代码:使用聚合管道

const pipeline = [
    { $match: { age: { $gte: 25 } } },
    { $group: { _id: "$city", total: { $sum: 1 } } },
    { $sort: { total: -1 } }
];
const results = await collection.aggregate(pipeline).toArray();
console.log(results);

7. 复制与分片

复制

MongoDB支持主从复制和副本集,以确保数据的高可用性。

分片

分片将数据分布到多个服务器上,以提高大数据集的性能和可扩展性。


总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,自学记录MongoDB基础知识点总览。


http://www.kler.cn/a/590822.html

相关文章:

  • 一条SQL在mysql数据库中经历的过程
  • STM32——基本定时器
  • 相机光学(四十七)——相纸材质
  • 神经网络量化3-全连接层实现量化
  • 相机标定之DLT算法学习
  • 对话傅盛:AI时代的超级应用是什么?
  • 【Python】10、集合
  • 使用fastapi部署stable diffusion模型
  • 3D点云目标检测——KITTI数据集读取与处理
  • 完全托管的DeepSeek-R1模型正式登陆Amazon Bedrock:安全部署与使用指南
  • Java的继承:方法;属性?
  • 个人学习编程(3-18) leetcode刷题
  • 在云平台上用Claude 3.7 AI代理自动化电脑图形界面点击操作做表格
  • PostgreSQL17允许psql的\watch在返回最小行数后停止
  • 2025年3月19日 十二生肖 今日运势
  • 电子硬件入门(三)——偏置电路
  • 模型评估——acc、P、R、F值、交叉验证、K折交叉验证
  • PATB1113 钱串子的加法
  • C++ 友元 / friend关键字解读
  • MongoDB 只能存储能够序列化的数据(比如字符串、数字等),而 Python 的 UUID 对象并不是直接可以存入数据库的格式。