python连接mysql数据库、FastAPI、mysql-connector-python

2024-06-12 02:28

本文主要是介绍python连接mysql数据库、FastAPI、mysql-connector-python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

方法工具一、FastAPI

 建议使用fast api中的pymysql

pip3 install fastapi
pip3 install pydantic
pip3 install "uvicorn[standard]"

pip3 中的3是 Python 3 版本的包管理器命令,用于安装和管理 Python 3 版本的第三方库。在某些系统中,同时安装了 Python 2 和 Python 3,为了区分两个版本的 pip 命令,Python 3 版本的 pip 命令被命名为 pip3。这样可以确保在命令行中使用 pip3 命令时,安装的库将会与 Python 3 版本关联。 

from fastapi import FastAPI
#项目名称 = FastAPI()
#如:link = FastAPI()
@link.get("/")
import pymysql
db = pymysql.connect(host='1.0.0.2',user='root',password='CSDN-jingyu1610',database='mysql',charset='utf8',autocommit=True,cursorclass=pymysql.cursors.DictCursor)
#解释
db = pymysql.connect(host='数据库IP地址',user='数据库',password='登录mysql数据库的密码,注意不是登录linux系统的密码',database='连接的数据库',charset='utf8',表示使用 UTF-8 字符集进行数据的编码和解码。autocommit=True,:表示开启自动提交模式。在自动提交模式下,每个 SQL 语句执行完成后会自动进行提交,不需要手动调用 commit() 方法。cursorclass=pymysql.cursors.DictCursor):表示使用字典类型的游标。使用字典类型的游标可以方便地通过列名来访问查询结果,而不是通过列索引。

使用 autocommit=True 和 cursorclass=pymysql.cursors.DictCursor 参数可以实现以下功能:

  • 开启自动提交,减少手动提交的操作。
  • 使用字典类型的游标,方便使用列名来操作查询结果。

详细解释charset='utf8'

表示使用 UTF-8 字符集进行数据的编码和解码。

UTF-8 是一种可变长度的字符编码方式,可以表示世界上几乎所有的字符。使用 UTF-8 编码可以保证数据在传输和存储时,不会出现字符乱码的问题。

设置 charset='utf8' 参数后,pymysql 在连接数据库时会将客户端和服务器之间的通信字符集设置为 UTF-8,这样可以保证数据库和应用程序之间的数据能够正确地进行编码和解码。

方法工具二、mysql-connector-python

mysql-connect-python工具不属于FastAPI当中。

要在Python中连接MySQL数据库,你可以使用一个称为mysql-connector-python的库。

首先,确保你已经安装了这个库。你可以使用以下命令进行安装:

如果不知道可以使用pip -V查看版本。 

一旦安装了库,你可以使用以下代码片段来连接到MySQL数据库:

确保将your_usernameyour_passwordyour_hostyour_databaseyour_table替换为你的实际值。这样你就可以连接到MySQL数据库并执行查询了。

pip3 install mysql-connector-python
import mysql.connector# 创建数据库连接
cnx = mysql.connector.connect(user='your_username', password='your_password',host='your_host', database='your_database')方法一、
# 执行SQL查询
mycursor.execute("SELECT * FROM yourtablename")# 获取查询结果
myresult = mycursor.fetchall()
for x in myresult:print(x)
#关闭连接在完成所有数据库操作后,应关闭游标和数据库连接
mycursor.close()
mydb.close()方法二、
# 创建游标对象,用于执行SQL查询
cursor = cnx.cursor()# 执行SQL查询
query = 'SELECT * FROM your_table'
cursor.execute(query)# 获取查询结果
for row in cursor:print(row)# 关闭游标和数据库连接
cursor.close()
cnx.close()

检查连接

您可以通过检查mydb.is_connected()来验证是否成功连接到数据库。

if mydb.is_connected():print("成功连接到MySQL数据库")

注意事项

  • 确保您的MySQL服务正在运行,并且您有正确的访问权限。
  • 根据您的数据库设置,数据库地址、端口等信息可能有所不同。
  • 在生产环境中,不要在代码中硬编码数据库凭据,应该使用配置文件或环境变量来管理这些敏感信息。

这篇关于python连接mysql数据库、FastAPI、mysql-connector-python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052938

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定