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

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

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

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

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. 连接池:在高并发环境下,使用连接池来提高性能。
相关推荐
qq_196976171 小时前
硬核项目管理:Gemini境像站驱动的WBS自动分解、关键路径识别与风险登记册生成(国内免费镜像实测)
数据库
身如柳絮随风扬1 小时前
CentOS 7 搭建 MySQL 主从复制集群:从零到生产级高可用
linux·mysql·centos
迷枫7121 小时前
DM8 读写分离集群学习总结:从部署规划到扩容排查
数据库·学习
csdn小瓯1 小时前
前端工程化:React + TypeScript + Tailwind CSS 的组件化实践
开发语言·人工智能·python
yuzhiboyouye1 小时前
聚合与分组统计 (GROUP BY)常用于web前端什么场景中
数据库
数据库小学妹1 小时前
MySQL 性能监控实战:从零搭建 Prometheus + Grafana 监控告警体系(附排查 SOP)
mysql·性能优化·grafana·prometheus·dba
hef2881 小时前
R包grafify:简单操作实现高效统计绘图
开发语言·python·r语言
这是谁的博客?1 小时前
Python 异步编程核心原理与实践深度解析
java·网络·python·协程·asyncio·异步编程
战南诚1 小时前
力扣 之 198.打家劫舍
python·算法·leetcode
AllData公司负责人1 小时前
亲测丝滑,体验跃迁|AllData通过集成开源项目StreamPark,实时流任务调度更省心!
java·大数据·数据库·人工智能·算法·实时计算·实时开发平台