当前位置: 首页 > article >正文

Python Web 应用:FastAPI 与 SQLAlchemy ORM

Python Web 应用:FastAPI 与 SQLAlchemy ORM

目录

  1. 🛠 安装与配置 SQLAlchemy
  2. 🏗 创建数据库模型(映射类)
  3. 🔄 数据库迁移:使用 Alembic
  4. 📝 数据库 CRUD 操作

1. 🛠 安装与配置 SQLAlchemy

SQLAlchemy 是 Python 中最流行的数据库框架之一,它支持两种主要的数据库操作方式:SQL 构建器和 ORM(对象关系映射)。使用 SQLAlchemy,开发者可以通过 Python 对象操作数据库,而无需编写 SQL 语句。通过其强大的功能和灵活性,SQLAlchemy 能够帮助开发者简化与数据库交互的复杂性。

安装 SQLAlchemy

安装 SQLAlchemy 非常简单,只需通过 pip 安装即可。在终端中执行以下命令:

pip install sqlalchemy

为了使 FastAPI 与 SQLAlchemy 配合使用,推荐同时安装 databases 库,它提供了异步支持,适合 FastAPI 的异步特性。可以通过以下命令安装:

pip install sqlalchemy databases

此外,如果要使用数据库迁移工具 Alembic,还需要安装:

pip install alembic
配置 SQLAlchemy

在 FastAPI 项目中,通常需要创建一个数据库引擎并与 SQLAlchemy 配合使用。以下是配置 SQLAlchemy 的步骤:

  1. 创建数据库引擎
    通过 create_engine 函数来设置与数据库的连接。SQLAlchemy 支持多种数据库,如 SQLite、MySQL 和 PostgreSQL。以下是连接 SQLite 数据库的示例:
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

# 配置数据库连接(此处使用 SQLite)
DATABASE_URL = "sqlite:///./test.db"

# 创建 SQLAlchemy 引擎
engine = create_engine(DATABASE_URL, connect_args={"check_same_thread": False})

# 创建一个基类,用于生成数据库模型类
Base = declarative_base()

# 创建会话(session)
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)

在上面的代码中,SessionLocal 是用来与数据库进行交互的会话类,而 Base 是所有 ORM 类的基类。

  1. 配置数据库会话
    在 FastAPI 中,常常需要管理数据库会话。为了避免每次请求都创建新的会话,通常将会话管理封装成一个依赖项,便于在不同的路由中重用。
from fastapi import Depends, FastAPI
from sqlalchemy.orm import Session

# 获取数据库会话
def get_db():
    db = SessionLocal()
    try:
        yield db
    finally:
        db.close()

app = FastAPI()

通过 get_db 依赖,FastAPI 在处理请求时会自动为每个请求提供数据库会话。


2. 🏗 创建数据库模型(映射类)

数据库模型(映射类)是将数据库表格结构映射到 Python 类的核心部分。通过使用 SQLAlchemy 的 ORM 功能,可以定义类来表示数据库中的每一张表。每个类的属性将对应数据库表的字段,而类的实例将代表表中的每一行记录。

定义数据库模型

以一个简单的用户信息模型为例,假设我们要为 Web 应用创建一个 User 表,该表包含 idnameemail 三个字段。以下是如何使用 SQLAlchemy 定义模型:

from sqlalchemy import Column, Integer, String

# 定义 User 模型类
class User(Base):
    __tablename__ = "users"

    id = Column(Integer, primary_key=True, index=True)
    name = Column(String, index=True)
    email = Column(String, unique=True, index=True)

在上述代码中:

  • Base 是我们在配置数据库时定义的基类。
  • __tablename__ 指定了数据库中对应的表名。
  • id 是主键列,nameemail 是普通字段,其中 email 列通过 unique=True 设置为唯一。
添加表到数据库

在定义好模型类后,我们可以通过 SQLAlchemy 创建对应的数据库表。通常可以在应用启动时运行以下代码来创建表格:

# 创建数据库表
Base.metadata.create_all(bind=engine)

这将根据 User 类的定义,自动创建 users 表。通过 metadata.create_all 方法,SQLAlchemy 会根据模型中的定义生成相应的 SQL 命令,并执行它们来创建表格。


3. 🔄 数据库迁移:使用 Alembic

随着 Web 应用的发展,数据库模型的结构往往会发生变化。为了避免每次修改模型后都需要手动更新数据库表结构,使用数据库迁移工具可以自动管理这些变更。Alembic 是 SQLAlchemy 官方推荐的迁移工具,它能帮助开发者在不丢失数据的前提下,轻松实现数据库结构的版本控制和迁移。

安装 Alembic

首先,需要通过 pip 安装 Alembic:

pip install alembic
初始化 Alembic

安装完成后,需要初始化 Alembic 配置文件:

alembic init alembic

这会在项目根目录下创建一个 alembic 文件夹,其中包含 env.pyscript.py.mako 等配置文件。在 alembic.ini 配置文件中,需要设置数据库的连接字符串:

# 在 alembic.ini 中设置 SQLAlchemy URL
sqlalchemy.url = sqlite:///./test.db
创建迁移脚本

每当数据库模型发生变更时,可以使用 Alembic 的自动生成功能生成迁移脚本:

alembic revision --autogenerate -m "create users table"

此命令会扫描数据库模型并生成对应的迁移脚本。如果模型发生了变化,Alembic 会生成 SQL 命令来反映这些变化。

应用迁移

生成迁移脚本后,可以使用以下命令将其应用到数据库:

alembic upgrade head

这会将最新的迁移应用到数据库中,从而确保数据库与模型保持同步。


4. 📝 数据库 CRUD 操作

FastAPI 与 SQLAlchemy 的集成让数据库操作变得更加简便。通过 SQLAlchemy 的 ORM,开发者可以使用 Python 对象进行数据增、删、改、查(CRUD)操作。以下是如何在 FastAPI 中进行常见的 CRUD 操作的示例。

创建数据

为了向数据库表中添加数据,首先需要创建数据模型的实例,并使用数据库会话进行添加:

from fastapi import Depends, FastAPI
from sqlalchemy.orm import Session

@app.post("/users/")
def create_user(name: str, email: str, db: Session = Depends(get_db)):
    db_user = User(name=name, email=email)
    db.add(db_user)
    db.commit()  # 提交事务
    db.refresh(db_user)  # 刷新,获取数据库中插入的 ID
    return db_user

上述代码中,create_user 路由接受 nameemail 作为输入,创建一个新的 User 实例,并将其添加到数据库中。

读取数据

读取数据的操作通常通过 query 方法来实现。以下是如何查询所有用户:

@app.get("/users/")
def read_users(skip: int = 0, limit: int = 10, db: Session = Depends(get_db)):
    users = db.query(User).offset(skip).limit(limit).all()
    return users

通过 offsetlimit 参数,可以实现分页查询。

更新数据

更新数据时,可以先查询目标记录,然后修改其属性并提交到数据库:

@app.put("/users/{user_id}")
def update_user(user_id: int, name: str, db: Session = Depends(get_db)):
    db_user = db.query(User).filter(User.id == user_id).first()
    if db_user:
        db_user.name = name
        db.commit()
        db.refresh(db_user)
    return db_user
删除数据

删除数据时,首先查询记录,之后使用 delete 方法进行删除:

@app.delete("/users/{user_id}")
def delete_user(user_id: int, db: Session = Depends(get_db)):
    db_user = db.query(User).filter(User.id == user_id).first()
    if db_user:
        db.delete(db_user)
        db.commit()
    return {"msg": "User deleted successfully"}

总结

使用 SQLAlchemy ORM 进行数据库操作可以极大简化与数据库的交互,尤其是在构建大规模应用时,通过 ORM 映射可以轻松管理数据库结构和数据。与 Alembic 配合使用时,开发者可以轻松地管理数据库迁移,保证数据库结构与应用模型的同步。通过本文的示例,可以快速掌握如何在 Fast

API 中使用 SQLAlchemy 实现完整的 CRUD 功能,进而构建出高效、可维护的 Web 应用。


http://www.kler.cn/a/430342.html

相关文章:

  • 第四、五章补充:线代本质合集(B站:小崔说数)
  • 文献综述拆解分析
  • Ubuntu中使用miniconda安装R和R包devtools
  • 嵌入式技术之Linux(Ubuntu) 一
  • 【Axios使用手册】如何使用axios向后端发送请求并进行数据交互
  • 部署:上传项目代码 配置数据库
  • 单词拼写纠正-03-72.力扣编辑距离 leetcode edit-distance
  • RISC-V架构下OP-TEE 安全系统实践
  • Python 爬虫 (1)基础 | XHR
  • ruoyi-nbcio为安全起见actuator为仅暴露health端点
  • 数据仓库实验二 实现警务数据仓库OLAP应用
  • 五天SpringCloud计划——DAY3之服务治理(Nacos+OpenFeign+OKHttp)
  • ubuntu16.04部署dify教程
  • 算法-字符串-165.比较版本号
  • 【UBOOT】【run_main_loop】uboot 启动 linux 内核
  • 使用javascript+canvas显示二叉树
  • DedeCMS最新注入漏洞(CNVD-2024-44514、CVE-2024-9076)
  • 怎么为开源项目做贡献提PR?
  • 企业经营数据分析系统:提升决策能力的利器
  • git中配置ssh的方法
  • 【计算机网络】实验15:VLAN间通信的实现方法“单臂路由”
  • 分布式事物各方案常见使用场景
  • PHP和GD库如何在图片上添加文字
  • 【IT】测试用例模版(含示例)
  • 踩坑日记-@Data注释的使用
  • 【机器学习】机器学习的基本概念、算法的工作原理、实际应用案例