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

2024-06-09 16:12

本文主要是介绍【fastapi+mongodb】使用motor操作mongodb(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这篇文章本来要介绍valgrind的,但是valgrind只能安装在 Linux 上,不得已,就继续上一篇文章写motor的用法。

如果你还没看过上一篇文章,地址在这:【fastapi+mongodb】使用motor操作mongodb

select

删除和修改都是基于查询的语法的。
使用 find_one() 得到匹配查询的第一个文档:

async def find_user_by_name():document_user = await collection_users.find_one({'name':'bluebonnet27'})print(document_user)

find_one支持匹配词进行辅助,和mongodb的方法一样。比如你只想返回名字(这要求很奇怪),可以这么写:

async def find_user_by_name_return_name():document_user = await collection_users.find_one({'name':'bluebonnet27'}, {'name': 1})print(document_user)

输出如下:

{'_id': ObjectId('6653321bbca655e427d1196f'), 'name': 'bluebonnet27'}

当然,同样的办法,如果_id也不想看到,也可以把它排除掉:

async def find_user_by_name_return_name():document_user = await collection_users.find_one({'name':'bluebonnet27'}, {'name': 1, '_id': 0})print(document_user)

find_one()同样支持条件匹配。比如,我们要查询年龄小于某个数字的user(lt是 less than):

async def find_user_by_lower_age(age: int):document_user = await collection_users.find_one({'age':{'$lt': age}})print(document_user)

使用 find() 可以查询一组文档。 find() 没有I / O,也不需要 await 表达式。它只是创建一个 AsyncIOMotorCursor 实例。调用to_list时,才需要进行await操作。注意,需要在to_list中指定length的大小,否则无法处理缓冲区溢出的问题:

async def find_users_by_name(name: str):users_cursor = collection_users.find({'name':name})for document_user in await users_cursor.to_list(length=100):print(document_user)

输出如下:

{'_id': ObjectId('6653321bbca655e427d1196f'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('6653323a3a2f7378d4fee103'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('6653325dfba58f88883ecd31'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('666404d0bd455a936bbf9dee'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('66650ee7ba035059d15c5b1d'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('666510181342c1d39f1b17e8'), 'name': 'bluebonnet27', 'age': 24}
{'_id': ObjectId('6665116aec1e9c66564df13d'), 'name': 'bluebonnet27', 'age': 24}

另一种写法是直接用async forcursor进行遍历:

async def find_users_by_name2(name: str):async for document_user in collection_users.find({'name':name}):print(document_user)

效果是一样的。

如果只是希望查询满足某个条件的文档的数量,可以使用count_documents(),这是更简单的函数:

async def get_users_num_by_name(name: str):return await collection_users.count_documents({'name':name})

main

    count: int = loop.run_until_complete(get_users_num_by_name('bluebonnet27'))print(count)

这篇关于【fastapi+mongodb】使用motor操作mongodb(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045659

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技