MongoDB(22)如何批量插入文档?

在MongoDB中,批量插入文档是非常常见且高效的操作。你可以使用MongoDB Shell或编程语言(如Node.js、Python和Java)来批量插入文档。下面是详细的步骤和代码示例,展示如何在不同环境中批量插入文档到MongoDB集合中。

在MongoDB Shell中批量插入文档

1. 启动MongoDB Shell

首先,打开终端或命令提示符,启动MongoDB Shell:

bash 复制代码
mongo

2. 选择数据库

选择你要插入文档的数据库:

javascript 复制代码
use myDatabase

3. 批量插入文档

使用 insertMany 方法批量插入文档到集合中。

javascript 复制代码
db.myCollection.insertMany([
    { name: "Alice", age: 30, city: "New York" },
    { name: "Bob", age: 25, city: "San Francisco" },
    { name: "Charlie", age: 35, city: "Los Angeles" }
])

使用Node.js批量插入文档

1. 安装MongoDB Node.js驱动

在终端中运行以下命令来安装MongoDB的Node.js驱动:

bash 复制代码
npm install mongodb

2. 创建并运行Node.js脚本

创建一个新的Node.js脚本文件(如 insertDocuments.js)并添加以下代码:

javascript 复制代码
const { MongoClient } = require('mongodb');

async function main() {
    const uri = "mongodb://localhost:27017";
    const client = new MongoClient(uri, { useUnifiedTopology: true });

    try {
        // 连接到MongoDB服务器
        await client.connect();
        console.log("Connected to MongoDB");

        // 选择数据库
        const db = client.db('myDatabase');

        // 选择集合
        const collection = db.collection('myCollection');

        // 批量插入文档
        const insertManyResult = await collection.insertMany([
            { name: "Alice", age: 30, city: "New York" },
            { name: "Bob", age: 25, city: "San Francisco" },
            { name: "Charlie", age: 35, city: "Los Angeles" }
        ]);

        console.log('Inserted documents:', insertManyResult.insertedCount);

    } finally {
        // 关闭连接
        await client.close();
    }
}

main().catch(console.error);

运行这个脚本:

bash 复制代码
node insertDocuments.js

使用Python批量插入文档

1. 安装PyMongo

在终端中运行以下命令来安装PyMongo:

bash 复制代码
pip install pymongo

2. 创建并运行Python脚本

创建一个新的Python脚本文件(如 insert_documents.py)并添加以下代码:

python 复制代码
from pymongo import MongoClient

def main():
    client = MongoClient('mongodb://localhost:27017/')

    # 选择数据库
    db = client['myDatabase']

    # 选择集合
    collection = db['myCollection']

    # 批量插入文档
    documents = [
        { 'name': 'Alice', 'age': 30, 'city': 'New York' },
        { 'name': 'Bob', 'age': 25, 'city': 'San Francisco' },
        { 'name': 'Charlie', 'age': 35, 'city': 'Los Angeles' }
    ]
    insert_many_result = collection.insert_many(documents)
    print('Inserted documents:', len(insert_many_result.inserted_ids))

    # 关闭连接
    client.close()

if __name__ == '__main__':
    main()

运行这个脚本:

bash 复制代码
python insert_documents.py

使用Java批量插入文档

1. 添加MongoDB Java驱动依赖

如果你使用的是Maven项目,添加以下依赖到你的 pom.xml 文件中:

xml 复制代码
<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongodb-driver-sync</artifactId>
    <version>4.4.0</version>
</dependency>

2. 创建Java类并添加代码

创建一个新的Java类文件(如 InsertDocuments.java)并添加以下代码:

java 复制代码
import com.mongodb.MongoClient;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import org.bson.Document;

import java.util.Arrays;

public class InsertDocuments {
    public static void main(String[] args) {
        // 连接到MongoDB服务器
        MongoClient mongoClient = new MongoClient("localhost", 27017);

        // 选择数据库
        MongoDatabase database = mongoClient.getDatabase("myDatabase");

        // 选择集合
        MongoCollection<Document> collection = database.getCollection("myCollection");

        // 创建文档列表
        Document doc1 = new Document("name", "Alice").append("age", 30).append("city", "New York");
        Document doc2 = new Document("name", "Bob").append("age", 25).append("city", "San Francisco");
        Document doc3 = new Document("name", "Charlie").append("age", 35).append("city", "Los Angeles");

        // 批量插入文档
        collection.insertMany(Arrays.asList(doc1, doc2, doc3));
        System.out.println("Inserted documents");

        // 关闭连接
        mongoClient.close();
    }
}

编译并运行这个Java类:

bash 复制代码
javac -cp .:path/to/mongodb-driver-sync-4.4.0.jar InsertDocuments.java
java -cp .:path/to/mongodb-driver-sync-4.4.0.jar InsertDocuments

总结

在MongoDB中批量插入文档的步骤如下:

  1. 启动MongoDB Shell :使用 mongo 命令启动MongoDB Shell。
  2. 选择数据库 :使用 use myDatabase 命令选择数据库。
  3. 批量插入文档 :使用 insertMany 方法批量插入文档。

此外,还可以使用Node.js、Python和Java来编写脚本或程序来批量插入文档。以上步骤和代码示例可以帮助你在不同编程语言和操作系统上实现批量插入文档到MongoDB集合中。

相关推荐
卷无止境2 小时前
podman与docker的区别和生产环境最佳实践
后端
程途知微3 小时前
ConcurrentHashMap线程安全实现原理全解析
java·后端
Mars酱3 小时前
1分钟编写贪吃蛇 | JSnake贪吃蛇单机版
java·后端·开源
卷卷说风控3 小时前
养了10年风控,今年开始养「虾」了
后端
王码码20353 小时前
Go语言中的Elasticsearch操作:olivere实战
后端·golang·go·接口
小旭95273 小时前
Spring Security 实现权限控制(认证 + 授权全流程)
java·后端·spring
weixin_408099673 小时前
【完整教程】天诺脚本如何调用 OCR 文字识别 API?自动识别屏幕文字实战(附代码)
前端·人工智能·后端·ocr·api·天诺脚本·自动识别文字脚本
金銀銅鐵3 小时前
[Java] 如何通过 cglib 的 FastClass 调用一个类中的“任意”方法?
java·后端
宠友信息4 小时前
一套基于uniapp+springboot完整社区系统是如何实现的?友猫社区源码级功能解析
java·spring boot·后端·微服务·微信·uni-app
小信丶5 小时前
Spring Cloud Stream EnableBinding注解详解:定义、应用场景与示例代码
java·spring boot·后端·spring