FastAPI框架为什么在启动时建表

一般采用的框架是使用FastAPI+sqlalchemy来进行数据库部分的操作,其中主要是分为以下几步:

  1. 使用脚本来进行建表(推荐)/直接在fastapi启动时进行建表(小项目)

为什么不采用fastapi的create_all方法来进行建表:

  • 如果是大项目有多个表多个实例,每个实例服务都去遍历一遍表导致速度缓慢
    • 会导致职责混淆,数据库建表按道理来说是运维部分的工作,fastapi启动服务是指可以使用整个服务了,所以无需再fastapi实例启动时建表

    • 如果大项目有多个实例服务,如果同时启动fastapi时使用create_all方法会出现对数据库进行锁的竞争导致卡死

    • fastapi的create_all方法只是会判断有没有表再进行判断,不会更新表的信息,如果添加/删除字段了更新表会出现ORM与数据库不对应的情况,并且在运行时没有报错,在运行时才会报错

    • fastapi启动时建表会导致数据库的版本无法管理,没办法进行回退

    • 采用fastapi建表没办法使用CI/CD(自动化集成/自动化部署)的整体流程,

      CI:
      ├─ lint # 代码检查,一般采用ruff
      ├─ test # 自动化测试
      ├─ migrate # 数据库迁移
      └─ build image # 打包成镜像

      CD:
      ├─ deploy # 部署
      └─ start app # 启动服务

  1. 数据库的配置,可以采用同步/异步的方式去进行实现,异步的话在同时操作数据库时就需要添加相关的锁/采用事务的方式防止出现同时操作一批数据导致出现脏数据
  2. 定义数据库的model,即ORM部分,要求ORM部分是与数据库进行对接的
相关推荐
倔强的石头_9 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神4 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据5 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_5 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡5 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧5 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon5 天前
SQL学习指南——视图
数据库·sql