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

fastapi mysql 开发restful 3

pip install mysql-connector-python pymysql

数据库链接

创建src目录,里面创建db.py 代码如下:

# 导入mysql.connector模块,该模块提供了与MySQL数据库进行连接和交互的功能。  
import mysql.connector  
  
# 定义一个函数get_db_connection,该函数用于获取与MySQL数据库的连接。  
def get_db_connection():  
    # 使用mysql.connector.connect()方法创建一个数据库连接对象。  
    # 这个方法需要几个关键参数来指定如何连接到数据库。  
    connection = mysql.connector.connect(  
        # host参数指定数据库服务器的地址,这里使用'localhost'表示数据库服务器运行在本机上。  
        host='localhost',  
          
        # port参数指定数据库服务器监听的端口号,MySQL默认端口是3306。  
        port=3306,  
          
        # user参数指定用于连接到数据库的用户名,这里使用的是"root"用户。  
        user="root",  
          
        # password参数指定连接数据库的密码,出于安全考虑,实际使用时密码不应明文写在代码中。  
        password="XXXXXXX",  
          
        # database参数指定要连接到的数据库名称,这里使用的是名为"database"的数据库。  
        database="database"  
    )  
      
    # 返回创建的数据库连接对象,以供后续操作使用。  
    return connection


def get_db():
    connection = get_db_connection()
    db = connection.cursor()

    try:
        yield db
    finally:
        db.close()
        connection.close()

main.py代码

# 导入FastAPI框架及相关依赖  
from fastapi import FastAPI, Depends, Header, HTTPException  
# 导入uvicorn,用于运行FastAPI应用  
import uvicorn  
# 从mysql.connector导入cursor,但这里可能存在问题,通常我们会导入connector然后从中获取cursor  
from mysql.connector import cursor  
# 导入自定义的数据库连接函数  
from src.db import get_db  
  
# 初始化FastAPI应用实例  
app = FastAPI()  
  
# 定义根路由,返回"Hello World"  
.get("/")  
async def root():  
    return {"message": "Hello World"}  
  
# 定义带参数的路由,返回带有输入名字的问候语  
.get("/hello/{name}")  
async def say_hello(name: str):  
    return {"message": f"Hello {name}"}  
  
# 定义关于信息的路由,返回应用名称和版本  
.get("/about")  
async def about():  
    """  
    项目信息  
    :return: 返回包含应用名称和版本信息的字典  
    """  
    return {  
        "app_name": "人工智能识别",  
        "app_version": "v0.0.1"  
    }  
  
# 定义获取所有用户的路由,从数据库中查询并返回用户列表  
.get("/users/")  
async def get_users(db: cursor.MySQLCursor = Depends(get_db)):  
    query = "SELECT * FROM view_set"  
    db.execute(query)  
    result = db.fetchall()  
    if result:  
        return {"users": result}  
    else:  
        return {"error": "User not found"}  
  
# 定义根据用户ID获取单个用户的路由  
.get("/users/{user_id}")  
async def get_user(user_id: int,  
                   db: cursor.MySQLCursor = Depends(get_db)):  
    query = "SELECT * FROM view_set WHERE id = %s"  
    db.execute(query, (user_id,))  
    result = db.fetchall()  
    if result:  
        return {"user_id": result[0][0], "username": result[0][1]}  
    else:  
        return {"error": "User not found"}  
  
# 定义插入用户的路由,但路由名称可能应该为/add_user/或其他更有意义的名称  
.get("/user_name/{user_name}")  
async def insert_user(user_name: str,  
                      db: cursor.MySQLCursor = Depends(get_db)):  
    query = "INSERT INTO view_set (name) VALUES (%s)"  
    db.execute(query, (user_name,))  
    # 注意:通常在执行INSERT操作后,我们不需要调用fetchone(),因为INSERT不返回结果集  
    # result = db.fetchone()  # 这行代码是多余的  
    db.execute("COMMIT")  # 注意:这里可能存在问题,通常我们不会在每个查询后都执行COMMIT,而是在适当的时候  
    return {"user_name": user_name}  
  
# 主程序入口  
if __name__ == "__main__":  
    # 使用uvicorn运行FastAPI应用  
    uvicorn.run(app, host="0.0.0.0", port=8000)  
    # 另一种运行方式,使用命令行参数--reload实现热重载  
    # uvicorn main:app --reload



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

相关文章:

  • 使用 ChatGPT 生成和改进你的论文
  • Redis延迟队列详解
  • 【Git版本控制器--1】Git的基本操作--本地仓库
  • 掌握C语言内存布局:数据存储的智慧之旅
  • 告别 Excel,拥抱 R 语言:开启数据分析新时代
  • 计算机二级-Java系列(Java的特点)
  • MongoDB的操作和理解
  • 6. 尚硅谷大数据111门技术+42个项目
  • ref和reactive, toRefs的使用
  • 计算机项目SpringBoot项目 办公小程序开发
  • haiku实现TemplatePairStack类
  • 【Linux】Linux权限(下)
  • 倒模专用制作耳机壳UV树脂:改性丙烯酸树脂
  • 保研机试算法训练个人记录笔记(三)
  • 代码随想录day18--二叉树的应用6
  • 速盾:cdn技术和原理是什么关系
  • transformers重要组件(模型与分词器)
  • 信息打点Day9
  • 02-Java抽象工厂模式 ( Abstract Factory Pattern )
  • 框架学习Maven
  • RabbitMQ-2.SpringAMQP
  • 算法专题:滑动窗口
  • 对于协同过滤算法我自己的一些总结和看法
  • 网易和腾讯面试题精选---性能和优化面试问题
  • Compose | UI组件(十三) | Navigation - 页面导航
  • thinkphp6入门(18)-- 中间件中除了handle函数,还可以有其它函数吗