如何使用 Python 连接 MySQL 数据库?

embedded/2025/2/26 22:02:25/

在Python开发中,连接MySQL数据库是一个常见的需求。

我们可以使用多种库来实现这一功能,其中最常用的是mysql-connector-pythonPyMySQL

下面我将详细介绍如何使用这两个库来连接MySQL数据库,并提供一些实际开发中的建议和注意事项。

mysqlconnectorpythonMySQL_10">1. 使用mysql-connector-python连接MySQL数据库

mysql-connector-python是MySQL官方提供的Python连接器,支持Python 3.x版本。

安装

首先,你需要安装mysql-connector-python库:

pip install mysql-connector-python
连接数据库

下面是一个简单的示例,展示如何连接到MySQL数据库

import mysql.connector# 创建数据库连接
mydb = mysql.connector.connect(host="localhost",user="yourusername",password="yourpassword",database="yourdatabase"
)# 创建游标对象
mycursor = mydb.cursor()# 执行SQL查询
mycursor.execute("SELECT * FROM yourtable")# 获取查询结果
myresult = mycursor.fetchall()for x in myresult:print(x)
注意事项
  1. 错误处理:在实际开发中,应该添加错误处理机制,以防止数据库连接失败或其他异常情况。

    try:
    mydb = mysql.connector.connect(
    host=“localhost”,
    user=“yourusername”,
    password=“yourpassword”,
    database=“yourdatabase”
    )
    except mysql.connector.Error as err:
    print(f"Error: {err}")

  2. 关闭连接:在完成数据库操作后,应该关闭游标和数据库连接,以释放资源。

    mycursor.close()
    mydb.close()

2. 使用PyMySQL连接MySQL数据库

PyMySQL是一个纯Python实现的MySQL客户端库,兼容Python 2.x和3.x版本。

安装

首先,你需要安装PyMySQL库:

pip install PyMySQL
连接数据库

下面是一个简单的示例,展示如何连接到MySQL数据库

import pymysql# 创建数据库连接
mydb = pymysql.connect(host="localhost",user="yourusername",password="yourpassword",database="yourdatabase"
)# 创建游标对象
mycursor = mydb.cursor()# 执行SQL查询
mycursor.execute("SELECT * FROM yourtable")# 获取查询结果
myresult = mycursor.fetchall()for x in myresult:print(x)
注意事项
  1. 错误处理:同样,应该添加错误处理机制。

    try:
    mydb = pymysql.connect(
    host=“localhost”,
    user=“yourusername”,
    password=“yourpassword”,
    database=“yourdatabase”
    )
    except pymysql.MySQLError as err:
    print(f"Error: {err}")

  2. 关闭连接:在完成数据库操作后,应该关闭游标和数据库连接。

    mycursor.close()
    mydb.close()

实际开发中的建议
  1. 使用上下文管理器:为了确保资源被正确释放,可以使用上下文管理器(with语句)来管理数据库连接和游标。

    import mysql.connector

    with mysql.connector.connect(
    host=“localhost”,
    user=“yourusername”,
    password=“yourpassword”,
    database=“yourdatabase”
    ) as mydb:
    with mydb.cursor() as mycursor:
    mycursor.execute(“SELECT * FROM yourtable”)
    myresult = mycursor.fetchall()
    for x in myresult:
    print(x)

  2. 参数化查询:为了避免SQL注入攻击,应该使用参数化查询。

    import mysql.connector

    with mysql.connector.connect(
    host=“localhost”,
    user=“yourusername”,
    password=“yourpassword”,
    database=“yourdatabase”
    ) as mydb:
    with mydb.cursor() as mycursor:
    sql = “SELECT * FROM yourtable WHERE id = %s”
    val = (1,)
    mycursor.execute(sql, val)
    myresult = mycursor.fetchall()
    for x in myresult:
    print(x)

  3. 连接池:在高并发环境下,可以使用连接池来管理数据库连接,提高性能。

    from mysql.connector.pooling import MySQLConnectionPool

    pool = MySQLConnectionPool(
    pool_name=“mypool”,
    pool_size=5,
    host=“localhost”,
    user=“yourusername”,
    password=“yourpassword”,
    database=“yourdatabase”
    )

    with pool.get_connection() as mydb:
    with mydb.cursor() as mycursor:
    mycursor.execute(“SELECT * FROM yourtable”)
    myresult = mycursor.fetchall()
    for x in myresult:
    print(x)

在Python中连接MySQL数据库,可以使用mysql-connector-pythonPyMySQL库。无论使用哪个库,都应该注意以下几点:

  1. 错误处理:添加错误处理机制,以防止异常情况。
  2. 关闭连接:在完成数据库操作后,关闭游标和数据库连接。
  3. 使用上下文管理器:使用上下文管理器来管理资源。
  4. 参数化查询:使用参数化查询来防止SQL注入攻击。
  5. 连接池:在高并发环境下,使用连接池来提高性能。

http://www.ppmy.cn/embedded/167372.html

相关文章

GB 44496-2024《汽车软件升级通用技术要求》标准解读|标准结构、测试方法、测试内容

2024年08月23日,我国工业和信息化部发布了GB 44496-2024《汽车软件升级通用技术要求》,该标准将于2026年01月01日起实施。该标准是一项强制性国家标准,适用于M类、N类和O类汽车。自该项标准实施之日起,所有需要申请道路机动车辆产…

git基本用法

原理图: 显示工作目录和暂存区的状态。 git status 三种状态:已提交(committed)、已修改(modified) 和 已暂存(staged) 配置 git config --global user.name "Your Name&qu…

C语言番外篇(4)--------->goto语句

在C语言中,有一个很特殊的语法,这就是goto语句。goto用于实现同一函数的跳转,goto后面会有一个标志,执行goto语句时,就会跳转到标志的位置。 一、goto语句的语法 (1)goto在前,标志…

【深度学习神经网络学习笔记(二)】神经网络基础

神经网络基础 神经网络基础前言1、Logistic 回归2、逻辑回归损失函数3、梯度下降算法4、导数5、导数计算图6、链式法则7、逻辑回归的梯度下降 神经网络基础 前言 Logistic 回归是一种广泛应用于统计学和机器学习领域的广义线性回归模型,主要用于解决二分类问题。尽…

R语言安装教程(附安装包)R语言4.3.2版本安装教程

文章目录 前言一、安装包下载二、R-4.3.2安装步骤三、rtools43安装步骤四、RStudio安装步骤 前言 本教程将详细、全面地为你介绍在 Windows 系统下安装 R 语言 4.3.2 的具体步骤。无论你是初涉数据领域的新手,还是希望更新知识体系的专业人士,只要按照本…

Java Web开发实战与项目——项目集成与部署

软件开发中,集成与部署是非常关键的一步。无论是将前端与后端模块进行有效的集成,还是通过自动化构建工具(如Maven)和CI/CD工具(如Jenkins)实现自动化部署,都会对项目的开发和发布流程产生深远影…

NLP的预处理数据

处理文本数据的主要工具是Tokenizer。Tokenizer根据一组规则将文本拆分为tokens。然后将这些tokens转换为数字,然后转换为张量,成为模型的输入。模型所需的任何附加输入都由Tokenizer添加。 如果您计划使用预训练模型,重要的是使用与之关联的…

check spring configuration解决方法

问题:导入新项目的时候打开idea,会出现checking spring configuration,如下弹窗 这个会极大耗费性能,把IDEA卡的不要不要的. 默默的等它运行完之后右下角出来了这个弹窗 根据提示是这2个文件目录下需要添加spring的配置文件, 直接点击提示的文字 “spring-boot-build.spring-bo…