如何使用python操作MySQL数据库

在这篇文章中,我们将详细介绍如何在Python中使用pymysql模块来操作MySQL数据库。pymysql是一个在Python程序中用来连接MySQL服务器并进行相关操作的库,它提供了丰富的API接口,可以满足各种操作MySQL数据库的需求。

一、安装pymysql

在Python中使用pymysql模块前,我们首先需要安装它。可以通过以下pip命令进行安装:

python 复制代码
pip install pymysql

二、连接到MySQL服务器

安装完成后,我们可以通过以下代码连接到MySQL服务器:

python 复制代码
import pymysql

# 连接数据库
db = pymysql.connect(host='localhost', user='root', password='root', database='test')

# 获取操作游标
cursor = db.cursor()

其中,host是MySQL服务器所在的主机名或IP地址,user是登录用户名,password是登录密码,database是需要操作的数据库名。

三、执行SQL语句

连接到数据库后,我们可以通过游标对象执行SQL语句。如下面的代码演示了插入、查询、更新和删除四种基本的SQL操作:

python 复制代码
# 插入数据
sql_insert = "INSERT INTO students(name, age) VALUES('Tom', 20)"
cursor.execute(sql_insert)
db.commit()  # 提交事务

# 查询数据
sql_select = "SELECT * FROM students"
cursor.execute(sql_select)
results = cursor.fetchall()  # 获取所有查询结果
for row in results:
    print(row)

    # 更新数据
sql_update = "UPDATE students SET age = 21 WHERE name = 'Tom'"
cursor.execute(sql_update)
db.commit()  # 提交事务

# 删除数据
sql_delete = "DELETE FROM students WHERE name = 'Tom'"
cursor.execute(sql_delete)
db.commit()  # 提交事务

注意,每次执行修改(包括插入、更新、删除)数据库的操作后,都需要调用db.commit()方法来提交事务,否则修改的结果不会被真正保存到数据库中。

四、异常处理

在执行SQL操作时,可能会出现各种各样的错误,如语法错误、操作非法等。为了防止程序因为这些错误而中断,我们可以使用Python的异常处理机制来捕获并处理这些错误:

python 复制代码
try:
    # 执行SQL语句
    cursor.execute(sql_insert)
    # 提交事务
    db.commit()
except Exception as e:
    # 如果出现错误,则回滚事务
    db.rollback()
    print("发生错误:", e)

五、关闭连接

在完成所有操作后,我们需要关闭游标和数据库连接,以释放资源:

python 复制代码
# 关闭游标和数据库连接
cursor.close()
db.close()

以上就是使用pymysql操作MySQL数据库的基本流程和方法。在实际使用过程中,还需要根据具体的需求和场景进行相应的调整和优化。希望本文能帮助你更好地理解和使用pymysql模块,更有效地在Python中操作MySQL数据库。

六、最后

如果觉得本文对你有帮助记得 **点个关注,给个赞,加个收藏,**更多精彩内容欢迎查看。

相关推荐
呱呱复呱呱2 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
Nturmoils3 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
曲幽7 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波7 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码7 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱17 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵18 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户0332126663671 天前
使用 Python 从零创建 Word 文档
python