MongoDB(1)什么是MongoDB?

MongoDB是一种开源的NoSQL数据库,使用文档型存储数据格式(类似于JSON的BSON格式),以解决传统关系型数据库在处理大数据和高并发场景中的局限性。

MongoDB的特点

  1. 文档存储:使用类似JSON的BSON格式存储数据。
  2. 灵活的模式:无需预定义表结构,支持动态模式。
  3. 高可用性:通过副本集实现数据的冗余和自动故障恢复。
  4. 水平扩展:通过分片技术实现数据分布到多个节点。
  5. 强大的查询能力:支持丰富的查询语法和聚合功能。

安装与配置

1. 安装 MongoDB

可以通过包管理器或者下载压缩包的方式安装MongoDB。在Ubuntu上,可以使用以下命令安装:

bash 复制代码
sudo apt-get update
sudo apt-get install -y mongodb

2. 启动和停止 MongoDB

启动MongoDB服务:

bash 复制代码
sudo service mongodb start

停止MongoDB服务:

bash 复制代码
sudo service mongodb stop

基本操作示例

1. 创建数据库和集合

javascript 复制代码
// 连接 MongoDB
const { MongoClient } = require('mongodb');
const url = 'mongodb://localhost:27017';
const client = new MongoClient(url);

async function run() {
    try {
        await client.connect();
        console.log("Connected to MongoDB");

        const db = client.db('mydatabase'); // 创建或选择数据库
        const collection = db.collection('users'); // 创建或选择集合

        // 插入文档
        const insertResult = await collection.insertOne({ name: "John Doe", email: "john.doe@example.com" });
        console.log('Inserted document:', insertResult.ops[0]);

        // 查询文档
        const user = await collection.findOne({ name: "John Doe" });
        console.log('Found document:', user);

        // 更新文档
        const updateResult = await collection.updateOne({ name: "John Doe" }, { $set: { email: "john.doe@newdomain.com" } });
        console.log('Updated document count:', updateResult.modifiedCount);

        // 删除文档
        const deleteResult = await collection.deleteOne({ name: "John Doe" });
        console.log('Deleted document count:', deleteResult.deletedCount);
    } finally {
        await client.close();
    }
}

run().catch(console.dir);

2. 使用索引

索引对于提高查询性能非常重要。以下示例展示如何创建索引:

javascript 复制代码
async function createIndex() {
    const { MongoClient } = require('mongodb');
    const url = 'mongodb://localhost:27017';
    const client = new MongoClient(url);

    try {
        await client.connect();
        const db = client.db('mydatabase');
        const collection = db.collection('users');

        // 创建索引
        const indexName = await collection.createIndex({ email: 1 });
        console.log('Created index:', indexName);

        // 查询使用索引
        const user = await collection.findOne({ email: "john.doe@newdomain.com" });
        console.log('Found document using index:', user);
    } finally {
        await client.close();
    }
}

createIndex().catch(console.dir);

3. 聚合操作

聚合操作用于处理数据并返回计算结果。以下示例展示如何进行聚合操作:

javascript 复制代码
async function aggregationExample() {
    const { MongoClient } = require('mongodb');
    const url = 'mongodb://localhost:27017';
    const client = new MongoClient(url);

    try {
        await client.connect();
        const db = client.db('mydatabase');
        const collection = db.collection('orders');

        // 插入多个文档
        await collection.insertMany([
            { product: "Apple", quantity: 10, price: 2.5 },
            { product: "Banana", quantity: 5, price: 1.2 },
            { product: "Orange", quantity: 8, price: 3.0 }
        ]);

        // 使用聚合管道计算总销售额
        const aggregationPipeline = [
            { $group: { _id: null, total: { $sum: { $multiply: ["$quantity", "$price"] } } } }
        ];

        const aggResult = await collection.aggregate(aggregationPipeline).toArray();
        console.log('Total sales:', aggResult[0].total);
    } finally {
        await client.close();
    }
}

aggregationExample().catch(console.dir);

高级功能

副本集

副本集(Replica Set)是MongoDB高可用性的实现方式。它由一个主节点(Primary Node)和多个从节点(Secondary Nodes)组成。

要配置副本集,需要在配置文件中添加以下内容:

yaml 复制代码
replication:
  replSetName: "rs0"

然后启动MongoDB实例并初始化副本集:

javascript 复制代码
rs.initiate()

分片

分片(Sharding)用于处理大量数据,将数据分布在多个服务器上。以下是分片的基本步骤:

javascript 复制代码
// 启用分片
sh.enableSharding("mydatabase")

// 为集合设置分片键
sh.shardCollection("mydatabase.users", { "_id": 1 })

总结

MongoDB是一种灵活、可扩展的NoSQL数据库,适用于处理大规模数据和高并发应用。通过丰富的API和各种高级特性,如副本集和分片,MongoDB提供了强大的数据存储和管理能力。上述示例展示了MongoDB的基本操作、索引使用、聚合操作以及高级功能的配置,是理解和掌握MongoDB的良好起点。

相关推荐
Victor3569 小时前
https://editor.csdn.net/md/?articleId=139321571&spm=1011.2415.3001.9698
后端
Victor35610 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
后端
灰子学技术11 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo81612 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang12 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
毕设源码_廖学姐13 小时前
计算机毕业设计springboot招聘系统网站 基于SpringBoot的在线人才对接平台 SpringBoot驱动的智能求职与招聘服务网
spring boot·后端·课程设计
野犬寒鸦14 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
逍遥德15 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
MX_935916 小时前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring