前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FastAPI-SQLAlchemy

FastAPI-SQLAlchemy

原创
作者头像
堕落飞鸟
发布2023-05-07 21:05:19
7830
发布2023-05-07 21:05:19
举报
文章被收录于专栏:飞鸟的专栏

SQLAlchemy

SQLAlchemy 是一个非常流行的 Python ORM,它提供了与各种数据库的集成,并且可以方便地实现数据库操作。FastAPI 提供了与 SQLAlchemy 的集成,可以方便地使用 SQLAlchemy ORM 操作数据库。

下面是一个使用 FastAPI 和 SQLAlchemy 的示例:

代码语言:javascript
复制
from fastapi import FastAPI
from sqlalchemy.orm import Session
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base

SQLALCHEMY_DATABASE_URL = "sqlite:///./test.db"
engine = create_engine(SQLALCHEMY_DATABASE_URL)
Base = declarative_base()

app = FastAPI()

@app.on_event("startup")
async def startup():
    Base.metadata.create_all(bind=engine)

@app.on_event("shutdown")
async def shutdown():
    Base.metadata.drop_all(bind=engine)

@app.get("/users/{user_id}")
async def read_user(user_id: int, db: Session = Depends(get_db)):
    user = db.query(User).filter(User.id == user_id).first()
    if not user:
        raise HTTPException(status_code=404, detail="User not found")
    return user

@app.post("/users/")
async def create_user(user: UserCreate, db: Session = Depends(get_db)):
    db_user = User(**user.dict())
    db.add(db_user)
    db.commit()
    db.refresh(db_user)
    return db_user

在上面的示例中,我们定义了一个名为 User 的 SQLAlchemy 模型,并在 startup 和 shutdown 事件中创建和删除数据库。然后我们在请求处理函数中使用 get_db 函数获取数据库会话,并使用 SQLAlchemy ORM 操作数据库。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • SQLAlchemy
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档