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

fastapi 后端项目目录结构 mysql fastapi 数据库操作

原文:fastapi 后端项目目录结构 mysql fastapi 数据库操作_mob6454cc786d85的技术博客_51CTO博客

一、安装sqlalchemy、pymysql模块

pip install sqlalchemy -i https://pypi.tuna.tsinghua.edu.cn/simple

pip install pymysql -i https://pypi.tuna.tsinghua.edu.cn/simple

注意,pymysql需要写进代码中,下面会有体现

二、创建数据库

 create database fastapi charset=utf8;

三、通过代码连接数据库并且测试

# 导入FastAPI模块
from fastapi import FastAPI
# 创建app实例
app = FastAPI()## 连接数据库# 连接mysql数据库需要导入pymysql模块
import pymysql
pymysql.install_as_MySQLdb()from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
# 配置数据库地址:数据库类型+数据库驱动名称://用户名:密码@机器地址:端口号/数据库名
engine =create_engine("mysql+pymysql://root:123@192.168.219.132:3306/fastapi",encoding='utf-8')
# 把当前的引擎绑定给这个会话;
# autocommit:是否自动提交 autoflush:是否自动刷新并加载数据库 bind:绑定数据库引擎
Session = sessionmaker(autocommit=False, autoflush=False, bind=engine)
# 实例化
session = Session()# declarative_base类维持了一个从类到表的关系,通常一个应用使用一个Base实例,所有实体类都应该继承此类对象
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()from sqlalchemy import Column, String, Integer
# 创建数据库模型(定义表结构:表名称,字段名称以及字段类型)
class User(Base):# 定义表名__tablename__ = 'tbluser'# 定义字段# primary_key=True 设置为主键userid = Column(Integer,primary_key=True)username = Column(String(255))# 构造函数def __init__(self,userid,username):self.userid = useridself.username = username# 打印形式def __str__(self):return "id:%s, name:%s" % (str(self.userid) ,self.username)# 在数据库中生成表
Base.metadata.create_all(bind=engine)

 通过uvicorn启动测试连接并且生成对象表

uvicorn app:app --port 8080 --host 127.0.0.1 --reload

 检查数据库看看是否成功

四、增删改查代码

# 导入FastAPI模块
from fastapi import FastAPI
# 创建app实例
app = FastAPI()## 连接数据库# 连接mysql数据库需要导入pymysql模块
import pymysql
pymysql.install_as_MySQLdb()from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
# 配置数据库地址:数据库类型+数据库驱动名称://用户名:密码@机器地址:端口号/数据库名
engine =create_engine("mysql+pymysql://root:123@192.168.219.132:3306/fastapi",encoding='utf-8')
# 把当前的引擎绑定给这个会话;
# autocommit:是否自动提交 autoflush:是否自动刷新并加载数据库 bind:绑定数据库引擎
Session = sessionmaker(autocommit=False, autoflush=False, bind=engine)
# 实例化
session = Session()# declarative_base类维持了一个从类到表的关系,通常一个应用使用一个Base实例,所有实体类都应该继承此类对象
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()from sqlalchemy import Column, String, Integer
# 创建数据库模型(定义表结构:表名称,字段名称以及字段类型)
class User(Base):# 定义表名__tablename__ = 'tbluser'# 定义字段# primary_key=True 设置为主键userid = Column(Integer,primary_key=True)username = Column(String(255))# 构造函数def __init__(self,userid,username):self.userid = useridself.username = username# 打印形式def __str__(self):return "id:%s, name:%s" % (str(self.userid) ,self.username)# 定义返回结果def to_dict(self):return {"userid": self.userid,"username": self.username}# 在数据库中生成表
Base.metadata.create_all(bind=engine)### 添加数据from pydantic import BaseModel
# 定义数据模型
class CreatUser(BaseModel):userid: intusername: strdef __str__(self):return "id:%s, name:%s" % (str(self.userid), self.username)## 添加单个
@app.post("/user/addUser")
async def InserUser(user: CreatUser):try:# 添加数据dataUser = User(userid=user.userid, username=user.username)session.add(dataUser)session.commit()session.close()except ArithmeticError:return {"code":"0002","message":"数据库异常"}return {"code":"0000","message":"添加成功"}from typing import List
## 添加多个
@app.post("/user/addUserList")
async def addUserList(*, user: List[CreatUser]):try:# user是一个列表,每个内部元素均为CreatUser类型for u in user:# 自定义的数据模型可以用.访问属性dataUser = User(userid=u.userid, username=u.username)session.add(dataUser)session.commit()session.close()except ArithmeticError:return {"code": "0002", "message": "数据库异常"}return {"code": "0000", "message": "添加成功"}### 查询## 按照user_id查询
@app.get("/user/{user_id}")
async def queryUserByUserId(user_id: int):# 创建Query查询,filter是where条件,调用one返回唯一行,调用all则是返回所有行try:# one与first的区别:# one:要求结果集中只有一个结果;如果数据库返回0或2个或更多结果,并且将引发异常,则为错误。# first:返回可能更大的结果集中的第一个,如果没有结果,则返回None。不会引发异常。# filter_by与filter的区别:# filter_by接收的参数形式是关键字参数,而filter接收的参数是更加灵活的SQL表达式结构# user1 = session.query(User).filter_by(userid=user_id).first()user1 = session.query(User).filter(User.userid==user_id).first()session.close()# 由于user1只有一个值,所以它直接是一个字典if user1:return {"code":"0000","message":"请求成功","data":user1}else:return {"code":"0001","message":"查询无结果"}except ArithmeticError:return {"code":"0002","message":"数据库异常"}## 查询所有
@app.get("/user/selectall/")
async def queryUserByUserId():# 创建Query查询,filter是where条件,调用one返回唯一行,调用all则是返回所有行try:user1 = session.query(User).all()session.close()# user1 是一个列表,内部元素为字典return {"code": "0000", "message": "请求成功", "data": user1}except ArithmeticError:return {"code":"0002","message":"数据库异常"}###删除# 根据user_id删除单个
@app.delete("/user/deleteUser/{user_id}")
async def deleteUser(user_id: int):try:user1 = session.query(User).filter(User.userid == user_id).first()if user1:session.delete(user1)session.commit()session.close()return {"code": "0000", "message": "删除成功"}else:return {"code": "0001", "message": "参数错误"}except ArithmeticError:return {"code": "0002", "message": "数据库错误"}from typing import List
## 删除多个
@app.delete("/user/deleteUserList")
async def deleteUser(user_ids: List[int]):try:for user_id in user_ids:user1 = session.query(User).filter(User.userid == user_id).first()if user1:session.delete(user1)session.commit()session.close()return {"code": "0000", "message": "删除成功"}except ArithmeticError:return {"code": "0002", "message": "数据库错误"}###修改## 根据user_id修改user_name
@app.put("/user/updateUser/")
# 定义查询参数user_id和user_name
async def updateUser(user_id: int, user_name: str):try:user1 = session.query(User).filter(User.userid == user_id).first()print(user1)if user1:user1.username = user_namesession.commit()session.close()return {"code": "0000", "message": "修改成功"}else:return {"code": "0001", "message": "参数错误"}except ArithmeticError:return {"code": "0002", "message": "数据库错误"}# 方式2:
class AlterUser(BaseModel):userid: intusername: str@app.put("/user/updateUser01/")
async def deleteUser(user: AlterUser):try:user1 = session.query(User).filter(User.userid == user.userid).first()if user1:user1.username = user.usernamesession.commit()session.close()return {"code": "0000", "message": "修改成功"}else:return {"code": "0001", "message": "参数错误"}except ArithmeticError:return {"code": "0002", "message": "数据库错误"}# if __name__ == '__main__':
#     import uvicorn
#     uvicorn.run(app=app, host="127.0.0.1", port=8000, debug=True)

这些代码的话可以通过 postman或者自带的api文档进行测试、

http://www.lryc.cn/news/252084.html

相关文章:

  • 研习代码 day47 | 动态规划——子序列问题3
  • L1-017:到底有多二
  • Python多线程使用(二)
  • 记录一次docker搭建tomcat容器的网页不能访问的问题
  • GPT3年终总结
  • Kafka生产者发送消息的流程
  • 基于SSM的数学竞赛网站设计与实现
  • 01-使用Git操作本地库,如初始化本地库,提交工作区文件到暂存区和本地库,查看版本信息,版本切换命令等
  • 排序算法介绍(二)冒泡排序
  • 搜索引擎高级用法总结: 谷歌、百度、必应
  • com.intellij.openapi.application.ApplicationListener使用
  • 常见js hook脚本
  • Java——SpringLayout弹簧布局
  • 正则表达式及文本三剑客grep sed awk
  • python爬虫之创建属于自己的ip代理池
  • 又添三位“信伙伴”,亚信安慧AntDB数据库与南京一鸣、广东鸿数、北京数见完成兼容互认
  • Linux --- 进程控制
  • SVG-椭圆弧-参数转换-计算公式-标准解读
  • 利用 LD_PRELOAD劫持动态链接库,绕过 disable_function
  • 网件R8500 trojan
  • 实现校园网开机自启动部署
  • pycharm 创建vue并实现简易路由功能
  • 2023年关于爬取Bilibili(B站)视频的一些最新资源和案例
  • HyperBDR云容灾v4.10.1发布,划重点:支持UCloud云平台自动化容灾+新增可灵活定义的备份策略
  • 第四十一篇,一次matlab与spdlog的合作
  • 【苍穹外卖】——第一天
  • 解决SecureFX的中文乱码问题
  • 【字符串匹配】【KMP算法】Leetcode 28 找出字符串中第一个匹配项的下标☆
  • 《洛谷深入浅出进阶篇》模意义下的乘法逆元+洛谷P3811
  • clickhouse -- clickhouse解析复杂JSON数组