【fastapi+mongodb】使用motor操作mongodb(三)

本篇文章介绍mongodb的删和改,下面是前两篇文章的链接:
【fastapi+mongodb】使用motor操作mongodb
【fastapi+mongodb】使用motor操作mongodb(二)

delete

delete 的用法基本和查找一致,包括delete_one(删除一个),delete_many(匹配到的全部删除),我们以delete_one为例:

python 复制代码
async def delete_user_by_name(name: str):
    delete_result = await collection_users.delete_one({'name':name})
    print(delete_result)
python 复制代码
loop.run_until_complete(delete_user_by_name('bluebonnet27'))

打印出来的result如下:

bash 复制代码
DeleteResult({'n': 1, 'ok': 1.0}, acknowledged=True

其实这个result看源代码就知道它的结构了:

python 复制代码
class DeleteResult(_WriteResult):
    """The return type for :meth:`~pymongo.collection.Collection.delete_one`
    and :meth:`~pymongo.collection.Collection.delete_many`
    """

    __slots__ = ("__raw_result",)

    def __init__(self, raw_result: Mapping[str, Any], acknowledged: bool) -> None:
        self.__raw_result = raw_result
        super().__init__(acknowledged)

    def __repr__(self) -> str:
        return f"{self.__class__.__name__}({self.__raw_result!r}, acknowledged={self.acknowledged})"

    @property
    def raw_result(self) -> Mapping[str, Any]:
        """The raw result document returned by the server."""
        return self.__raw_result

    @property
    def deleted_count(self) -> int:
        """The number of documents deleted."""
        self._raise_if_unacknowledged("deleted_count")
        return self.__raw_result.get("n", 0)

因此我们可以调用deleted_count方法返回被删除的数据个数,以及是否删除成功(delete方法本身是不会报异常的,没有满足要求的数据就什么都不执行)

update

更新主要是两类函数:replace和update,前者会用传入的对象整个覆盖掉document(就算你传入的是个空的document),后者可以选择修改哪些字段。

我们先以replace_one为例子:

python 复制代码
async def replace_user():
    document_user = await collection_users.find_one({'name':'bluebonnet28'})
    _id = document_user['_id']
    replace_result = await collection_users.replace_one({'_id': _id}, {'age': 30})
    print(replace_result.matched_count)
    print(replace_result.modified_count)

整个文档都会被替换,除了id,因此名字也没了,新的文档如下:

试试温和一点的update_one

python 复制代码
async def update_name_of_user_by_age(age: int, name: str):
    update_result = await collection_users.update_one({'age': age}, {'$set': {'name': name}})
    print(update_result.matched_count)
    print(update_result.modified_count)
python 复制代码
loop.run_until_complete(update_name_of_user_by_age(30, 'name'))

我们将刚才的数据重新修改了下,现在它是这样的:

相关推荐
用户83562907805113 小时前
用Python轻松管理Word页脚:批量处理与多节文档技巧
后端·python
进击的松鼠13 小时前
LangChain 实战 | 快速搭建 Python 开发环境
python·langchain·llm
小北方城市网13 小时前
第1课:架构设计核心认知|从0建立架构思维(架构系列入门课)
大数据·网络·数据结构·python·架构·数据库架构
想用offer打牌13 小时前
一站式了解Spring AI Alibaba的流式输出
java·人工智能·后端
秋说13 小时前
华为 DevKit 25.2.rc1 源码迁移分析使用教程(openEuler + ARM64)
后端
ServBay13 小时前
C# 成为 2025 年的编程语言,7个C#技巧助力开发效率
后端·c#·.net
我的offer在哪里13 小时前
Hugging Face:让大模型触手可及的魔法工厂
人工智能·python·语言模型·开源·ai编程
汤姆yu14 小时前
基于python大数据的协同过滤音乐推荐系统
大数据·开发语言·python
爱学习的小道长14 小时前
Python Emoji库的使用教程
开发语言·python
行百里er14 小时前
一个还没写代码的开源项目,我先来“画个饼”:Spring Insight
后端·开源·github