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

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来调用函数进行查询和其他的操作

http://www.cnnetsun.cn/news/52212.html

相关文章:

  • 基于VUE的实验室使用管理系统[VUE]-计算机毕业设计源码+LW文档
  • 【单片机毕业设计】【mcugc-mcu911】基于单片机的多功能安防系统
  • 【单片机毕业设计】【mcugc-mcu916】基于单片机的智能家居安防系统
  • 基于vue的家庭服务预约管理系统的设计与实现_f1709smp_springboot php python nodejs
  • Java---小球移动案例(附代码)
  • 分享一个夸克网盘不限速的下载方法-在线免费工具
  • 1、现代 C++ 挑战:从基础到实战
  • 当数据回归遇上暴击流:SVM Adaboost实战手札
  • 65、文件管理子系统与网络协议通信概述
  • DAY18 机器学习
  • jd.item_review获取京东商品评论 及tb.item_review获取taobao商品评论
  • Windows11系统文件verifier.dll丢失或损坏问题 下载修复
  • C++树形数据结构————树状数组、线段树中“逆序对”的问题
  • 2025年B站视频下载终极指南:bilili工具完整使用教程
  • 教程 32 - 几何体系统
  • Cursor高级技巧与最佳实践
  • Cursor + MCP:冲击的不仅是前端,而是整个软件开发范式!
  • 2025年十大旗舰对决:极致轻薄成高端手机新战场
  • 【Vue3】 中 ref 与 reactive:状态与模型的深入理解
  • 毕设 stm32 RFID员工打卡门禁系统(源码+硬件+论文)
  • 全球最大、最领先的吉利全球全域安全中心正式发布
  • Android中Compose系列之按钮Button
  • wangEditor导入excel数据到html富文本编辑
  • 光伏电池simulink仿真模型 光伏电池建模仿真 包括改变温度 改变辐照度的特性分析 模型可...
  • JSP中如何利用分块技术实现百万文件上传优化?
  • 60、Ubuntu 安装硬件规划全攻略
  • 2025年12月— CET四六级答案
  • 锐捷RGSP | 端口安全技术原理与应用
  • Cameralink采集卡软件EspeedGrab使用讲解:4图像处理
  • 31、脚本编程进阶:Here文档、自上而下设计与流程控制