FastAPI使用异步motor实现对mongodb的增删改查

一、环境准备:

需要有mongodbpoetry以及Python3.10+

二、克隆示例代码到本地

bash 复制代码
git clone git@github.com:waketzheng/fastapi_async_mongo_demo.git

三、安装依赖

bash 复制代码
cd fastapi_async_mongo_demo
poetry shell
poetry install

四、启动服务

bash 复制代码
python app/main.py

五、访问本地文档

http://localhost:8000/docs

六、代码详解:

目录如下:

python 复制代码
.
├── app
│   ├── db.py
│   ├── main.py
│   ├── schemas
│   │   ├── __init__.py
│   │   ├── item.py
│   │   └── user.py
│   ├── utils.py
│   └── views.py
├── poetry.lock
├── pyproject.toml
└── README.md
  1. 数据库连接(app/db.py)
python 复制代码
from pathlib import Path
from typing import TYPE_CHECKING

import motor.motor_asyncio

if TYPE_CHECKING:
    from motor.core import AgnosticClient

client: "AgnosticClient" = motor.motor_asyncio.AsyncIOMotorClient("localhost", 27017)
db_name = Path(__file__).parent.parent.name.replace("-", "_")
database = client[db_name]
github/fastapi_async_mongo_demo [main●] >> vi app/db.py
github/fastapi_async_mongo_demo [main●] >> cat app/db.py
from pathlib import Path
from typing import TYPE_CHECKING

import motor.motor_asyncio

if TYPE_CHECKING:
    from motor.core import AgnosticClient

client: "AgnosticClient" = motor.motor_asyncio.AsyncIOMotorClient("localhost", 27017)
db_name: str = Path(__file__).parent.parent.name.replace("-", "_")
database = client[db_name]
  1. 启动服务器时,挂载数据库连接实例(app/main.py)
python 复制代码
from contextlib import asynccontextmanager
from fastapi import FastAPI
from db import database

@asynccontextmanager
async def lifespan(app: FastAPI):
    app.state.db = database
    yield


app = FastAPI(lifespan=lifespan)
  1. 根据用户传入的id,查询数据库,返回json格式的数据给用户
python 复制代码
from bson.objectid import ObjectId
from fastapi import Request


@app.get("/items/{id}")
async def item_data(request: Request, id: str) -> dict:
    collection = request.app.state.db['item']
    obj = await collection.find_one({"_id": ObjectId(id)})
    data = {'id': str(obj['_id']), 'name': obj['name']} 
    return data
  1. 增删改
python 复制代码
# 增
data = {'name': 'xx', 'description': None}
inserted = await collection.insert_one(data)
object_id: str = str(inserted.inserted_id)

# 改
data = {'name': 'new_name'}
await collection.update_one({"_id": ObjectId(id)}, {"$set": data})

# 删
await collection.delete_one({"_id": ObjectId(id)})

# 查询所有记录
objs = []
async for obj in self.collection.find():
    objs.append(obj)
相关推荐
阿波罗尼亚5 小时前
数据库序列(Sequence)
数据库
Junsir大斗师5 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish5 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
m0_596749097 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
老纪的技术唠嗑局7 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
2301_7950997410 小时前
golang如何在Gin中自定义验证器_golang Gin自定义验证器实现方法
jvm·数据库·python
2301_7662834410 小时前
如何在MongoDB GridFS中进行按文件大小(length)范围的查询
jvm·数据库·python
萧曵 丶11 小时前
MySQL 高频面试题(由浅到深 完整版,面试必背)
数据库·mysql·面试
czlczl2002092511 小时前
MySQL 执行引擎:排序与临时表机制深度解析
数据库·mysql
lifewange11 小时前
DBeaver如何安装
数据库