news 2026/2/27 1:14:49

SQLALchemy与fastapi结合的基本流程与注意事项整理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQLALchemy与fastapi结合的基本流程与注意事项整理

文章目录

  • 一、模块导入
  • 二、初始化FastAPI对象
  • 三、数据库配置
    • 1、定义 SQLite 数据库的连接路径
    • 2、创建数据库连接
    • 3、创建会话
  • 四、创建数据库模型
    • 1、创建一个基础类
    • 2、定义数据库模型
  • 五、创建数据库表
  • 六、创建用户模型
  • 七、设置接口实例

一、模块导入

fromfastapiimportFastAPI,HTTPExceptionfrompydanticimportBaseModelfromsqlalchemyimportcreate_engine,Column,Integer,Stringfromsqlalchemy.ormimportsessionmaker,declarative_base

二、初始化FastAPI对象

app=FastAPI()

三、数据库配置

1、定义 SQLite 数据库的连接路径

database_url="sqlite:///./text2.db"

sqlite:///:代表使用sqlite数据库,后面的 ./text2.db 代表该数据库的相对路径

2、创建数据库连接

engine=create_engine(database_url,connect_args={"check_same_thread":False})

第一个参数为要创建的数据库的地址,第二个参数为check_same_thread: 设置为 False 时,允许在不同线程间共享数据库连接,
对于具体区别,可以看作添加该参数:允许跨线程使用数据库连接
不添加该参数:需要确保每个线程都有独立的数据库连接,否则就会报错

3、创建会话

SessionLocal=sessionmaker(autocommit=False,autoflush=False,bind=engine)

这里的参数一是关闭自动提交,参数二为关闭自动刷新,参数三为指定要操作的数据库连接
这里是创建了一个数据库会话工厂 SessionLocal,用于生成数据库会话对象也就是对数据库的操作对象

四、创建数据库模型

1、创建一个基础类

Base=declarative_base()

declarative_base(): 这是 SQLAlchemy 提供的一个工厂函数,用于创建一个基类,这个基类是使用声明式语法定义数据库表模型的基础

2、定义数据库模型

classLogin(Base):# 表名__tablename__="login"id=Column(Integer,primary_key=True,index=True)username=Column(String,unique=True,index=True)password=Column(String)classUser(Base):# 表名__tablename__="user"id=Column(Integer,primary_key=True,index=True)name=Column(String)age=Column(Integer)address=Column(String)numberphone=Column(String)

五、创建数据库表

Base.metadata.create_all(bind=engine)

如果bind=engin的数据库连接对应的数据库表不存在,则创建

六、创建用户模型

classUserCreate(BaseModel):name:strage:int|None=Noneaddress:str|None=Nonenumberphone:str|None=None

小技巧:除一定会传入的参数外,其他参数可以使用设空值的方法来优化后续的传参步骤

七、设置接口实例

@app.get("/login")deflogin(login:LoginCreate):try:session=SessionLocal()user_db=session.query(Login).filter(Login.username==login.username,Login.password==login.password).first()ifuser_db:returnf"{login.username}登录成功!"else:return"用户名或密码错误"exceptExceptionase:returnf"登录失败:{e}"

!!!注意:对于SQLALchemy在接口内对数据库进行操作的前提是要创建一个会议对象,也就是session = SessionLocal(),然后通过session来调用函数进行查询和其他的操作

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/20 9:52:28

测试可编程运放 MCP6S21

使用MCP6S22检测导航信号特性测试 **AD\Test\2025\December\TestMCP6S21STG8SOP8.SchDoc *** 增益可编程放大器MCP6S2101 MCP6S21测试特性 一、背景简介 之前测试了增益可编程运放 MCP6S22,  现在购买的 MCP6S21 芯片到货了, 它内部运放具有信号参考地…

作者头像 李华
网站建设 2026/2/26 5:47:54

月周日虚拟成交量通达信指标源码贴图

{}WD:IF(WEEKDAY<5,WEEKDAY,1);{返回周几} WDM:(WEEKDAY-1)*240FROMOPEN;{计算本周的开盘分钟数} CD:DAY; TWD:WEEKDAY; CMD:30; YINZI:7-(CD MOD 7)-TWD; CMW:((CMDYINZI)-1)*5TWD; V1:DAY;{日期} V2:WEEKDAY; V3:V2-(V1-INTPART(V1/7)*7); {取得当日和7以及周几的关连因子…

作者头像 李华
网站建设 2026/2/16 4:28:17

通达信涨停板主图 源码

{}VAR1:EMA(CLOSE,12)-EMA(CLOSE,26); JL01:MA(C,3); LJL07:(3*CLOH)/6; 牛线:(20*LJL0719*REF(LJL07,1)18*REF(LJL07,2)17*REF(LJL07,3)16*REF(LJL07,4)15*REF(LJL07,5)14*REF(LJL07,6)13*REF(LJL07,7)12*REF(LJL07,8)11*REF(LJL07,9)10*REF(LJL07,10)9*REF(LJL07,11)8*REF(LJ…

作者头像 李华
网站建设 2026/2/21 20:27:12

天机学堂-排行榜功能-day08(六)

接口 一 实时排行榜 1.查询赛季列表功能参数说明请求方式GET请求路径/boards/seasons/list请求参数无返回值[ { "id": "110", // 赛季id "name": "第一赛季", // 赛季名称 "beginTime": "2023-05-01", …

作者头像 李华
网站建设 2026/2/24 7:38:50

54、深入解析STREAMS机制:从流头操作到终端控制

深入解析STREAMS机制:从流头操作到终端控制 1. 流头操作:qattach()与qdetach() 当打开一个模块或驱动程序时, qattach() 函数会被调用。其主要作用是为驱动程序或模块设置一个队列对,并调用其 open 函数。 qattach() 的参数之一是一个现有的队列对,新的队列对将链…

作者头像 李华
网站建设 2026/2/20 11:14:04

12、C++ 数据序列化与文件处理实战

C++ 数据序列化与文件处理实战 在 C++ 编程中,数据序列化和文件处理是非常重要的部分。本文将详细介绍如何使用不同的库进行 XML、JSON 数据的序列化和反序列化,以及如何创建包含图像的 PDF 文件和处理 ZIP 归档文件。 1. XML 数据的序列化和反序列化 在 C++ 标准库中,没…

作者头像 李华