MongoDB(21)如何删除MongoDB集合中的文档?

6 阅读3分钟

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

在MongoDB Shell中删除文档

1. 启动MongoDB Shell

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

mongo

2. 选择数据库

选择你要删除文档的数据库:

use myDatabase

3. 删除文档

使用 deleteOnedeleteManyfindOneAndDelete 方法删除集合中的文档。

删除单个文档:

db.myCollection.deleteOne({ name: "Alice" })  // 查询条件

删除多个文档:

db.myCollection.deleteMany({ city: "NYC" })  // 查询条件

使用 findOneAndDelete 删除并返回已删除的文档:

db.myCollection.findOneAndDelete({ name: "Bob" })  // 查询条件

使用Node.js删除文档

1. 安装MongoDB Node.js驱动

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

npm install mongodb

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

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

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 deleteOneResult = await collection.deleteOne(
            { name: "Alice" }  // 查询条件
        );
        console.log('Delete One Result:', deleteOneResult);

        // 删除多个文档
        const deleteManyResult = await collection.deleteMany(
            { city: "NYC" }  // 查询条件
        );
        console.log('Delete Many Result:', deleteManyResult);

        // 使用 findOneAndDelete 删除并返回已删除的文档
        const findOneAndDeleteResult = await collection.findOneAndDelete(
            { name: "Bob" }  // 查询条件
        );
        console.log('Find One and Delete Result:', findOneAndDeleteResult.value);

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

main().catch(console.error);

运行这个脚本:

node deleteDocument.js

使用Python删除文档

1. 安装PyMongo

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

pip install pymongo

2. 创建并运行Python脚本

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

from pymongo import MongoClient

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

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

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

    # 删除单个文档
    delete_one_result = collection.delete_one(
        { 'name': 'Alice' }  # 查询条件
    )
    print('Delete One Result:', delete_one_result.deleted_count)

    # 删除多个文档
    delete_many_result = collection.delete_many(
        { 'city': 'NYC' }  # 查询条件
    )
    print('Delete Many Result:', delete_many_result.deleted_count)

    # 使用 find_one_and_delete 删除并返回已删除的文档
    find_one_and_delete_result = collection.find_one_and_delete(
        { 'name': 'Bob' }  # 查询条件
    )
    print('Find One and Delete Result:', find_one_and_delete_result)

    # 关闭连接
    client.close()

if __name__ == '__main__':
    main()

运行这个脚本:

python delete_document.py

使用Java删除文档

1. 添加MongoDB Java驱动依赖

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

<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>mongodb-driver-sync</artifactId>
    <version>4.4.0</version>
</dependency>

2. 创建Java类并添加代码

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

import com.mongodb.MongoClient;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import org.bson.Document;

import static com.mongodb.client.model.Filters.eq;

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

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

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

        // 删除单个文档
        collection.deleteOne(eq("name", "Alice"));
        System.out.println("Deleted one document where name is 'Alice'");

        // 删除多个文档
        collection.deleteMany(eq("city", "NYC"));
        System.out.println("Deleted all documents where city is 'NYC'");

        // 使用 findOneAndDelete 删除并返回已删除的文档
        Document deletedDoc = collection.findOneAndDelete(eq("name", "Bob"));
        System.out.println("Find One and Delete Result: " + deletedDoc.toJson());

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

编译并运行这个Java类:

javac -cp .:path/to/mongodb-driver-sync-4.4.0.jar DeleteDocument.java
java -cp .:path/to/mongodb-driver-sync-4.4.0.jar DeleteDocument

总结

在MongoDB中删除文档的步骤如下:

  1. 启动MongoDB Shell:使用 mongo 命令启动MongoDB Shell。
  2. 选择数据库:使用 use myDatabase 命令选择数据库。
  3. 删除文档:使用 deleteOnedeleteManyfindOneAndDelete 方法删除文档。

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