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

Python 操作 MySQL 事务:从入门到避坑

在实际开发中,单条 SQL 往往不够用。转账、订单处理、库存扣减……这些场景要求多条 SQL要么全成功,要么全失败。这就是事务存在的意义。

本文用 Python 实战讲解如何正确使用 MySQL 事务,覆盖pymysqlmysql-connector-pythonSQLAlchemy三种主流方式。


一、先搞懂事务的核心:ACID

特性含义举例
Atomicity(原子性)操作不可分割,全做或全不做转账:扣款和入账必须同时成功
Consistency(一致性)事务前后数据保持一致余额不能凭空消失
Isolation(隔离性)并发事务互不干扰两人同时取钱,不能互相影响
Durability(持久性)提交后数据永久保存服务器重启数据不丢失

一句话:事务就是保证数据不出乱子的机制。


二、方式一:pymysql(最常用)

2.1 基本用法

importpymysql conn=pymysql.connect(host='localhost',user='root',password='your_password',database='test_db',charset='utf8mb4')try:withconn.cursor()ascursor:# 开启事务(默认就是手动提交模式)sql1="UPDATE accounts SET balance = balance - 100 WHERE user_id = 1"sql2="UPDATE accounts SET balance = balance + 100 WHERE user_id = 2"cursor.execute(sql1)cursor.execute(sql2)# 全部成功,提交conn.commit()print("转账成功")exceptExceptionase:# 任何一步出错,回滚conn.rollback()print(f"转账失败,已回滚:{e}")finally:conn.close()

2.2 关键点

  • conn.commit()提交事务
  • conn.rollback()回滚事务
  • 出错必须回滚,否则已执行的 SQL 不会撤销
  • 默认autocommit=False,所以需要手动提交

三、方式二:mysql-connector-python(官方驱动)

importmysql.connector conn=mysql.connector.connect(host='localhost',user='root',password='your_password',database='test_db')cursor=conn.cursor()try:cursor.execute("UPDATE accounts SET balance = balance - 100 WHERE user_id = 1")cursor.execute("UPDATE accounts SET balance = balance + 100 WHERE user_id = 2")conn.commit()exceptmysql.connector.Erroraserr:conn.rollback()print(f"Error:{err}")finally:cursor.close()conn.close()

pymysql逻辑一致,只是 API 略有不同。


四、方式三:SQLAlchemy ORM(推荐大型项目)

fromsqlalchemyimportcreate_engine,Column,Integer,Stringfromsqlalchemy.ormimportsessionmaker,declarative_base Base=declarative_base()classAccount(Base):__tablename__='accounts'id=Column(Integer,primary_key=True)name=Column(String(50))balance=Column(Integer)engine=create_engine('mysql+pymysql://root:password@localhost/test_db')Session=sessionmaker(bind=engine)session=Session()try:account1=session.query(Account).filter_by(id=1).with_for_update().first()account2=session.query(Account).filter_by(id=2).with_for_update().first()account1.balance-=100account2.balance+=100session.commit()print("转账成功")exceptExceptionase:session.rollback()print(f"转账失败:{e}")finally:session.close()

为什么用with_for_update()

普通查询在并发下可能读到脏数据。with_for_update()加行锁,确保这条记录在事务结束前不被其他事务修改,解决并发问题。


五、三种方式对比

维度pymysqlmysql-connectorSQLAlchemy
上手难度⭐⭐⭐⭐⭐⭐⭐
性能稍慢(有 ORM 开销)
适用场景轻量脚本、小项目官方驱动、稳定需求中大型项目
并发控制手动写 SQL手动写 SQLwith_for_update()内置

选型建议:小项目用pymysql,追求稳定用官方驱动,项目大了直接上 SQLAlchemy。


六、常见坑 & 最佳实践

坑1:异常没捕获,事务没回滚

# ❌ 错误示范cursor.execute(sql1)cursor.execute(sql2)# 如果这里报错,sql1 已执行但没回滚conn.commit()

必须用 try/except 包裹,except 里调用rollback()

坑2:连接池里的事务混乱

用连接池时,确保一个连接只处理一个事务,不要跨连接做事务操作。

坑3:忘了设置隔离级别

MySQL 默认隔离级别是REPEATABLE READ,但有些场景需要READ COMMITTED

conn.begin()# 显式开启事务cursor.execute("SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED")

最佳实践清单

  • ✅ 事务里的 SQL 尽量少,减少锁持有时间
  • ✅ 捕获所有异常,确保回滚
  • ✅ 高并发场景加行锁(SELECT ... FOR UPDATE
  • ✅ 生产环境用连接池(如DBUtilsSQLAlchemy内置池)
  • ✅ 不要在事务里做网络请求、文件 IO 等耗时操作

七、总结

你的场景推荐方案
写个脚本批量处理数据pymysql+ 手动 commit/rollback
官方项目,求稳定mysql-connector-python
Web 项目、多人协作SQLAlchemy+with_for_update()

事务不复杂,但用错了比不用更危险。记住三个动作:begin → commit / rollback → close,就能覆盖 90% 的场景。

http://www.gsyq.cn/news/1428952.html

相关文章:

  • 避坑指南:Unity Input Field事件(OnValueChanged/OnEndEdit)的触发时机与常见误用
  • 2026年泸州白酒OEM代工与企业定制:源头酒厂直营模式解读 - 优质企业观察收录
  • 2026 杭州除异味公司推荐,厨卫地下室顽固臭味治理,甄选长效不反弹靠谱治理企业 - 品牌榜中榜
  • 3步告别公式噩梦:LaTeX2Word-Equation如何让数学公式迁移变得轻松
  • 模拟电路图到网表的自动化转换技术解析
  • 从灰度图到彩图:ENVI中土地利用分类数据的显示与制图避坑指南
  • 如何用QKeyMapper打造终极Windows按键映射方案:免费开源工具完全指南
  • 杭州低糖健康糕点排行榜!减脂老人小孩都能吃,伴手礼不踩雷 - 玖叁鹿geo
  • wvp-GB28181-pro:构建智能视频监控平台的数字化转型突破
  • Keil μVision调试器变量观察冲突解决方案
  • 用Python手搓一个线段树:从数组到区间查询的保姆级实现(附LeetCode实战)
  • Arduino与FastLED库驱动WS2811像素LED:从硬件连接到动态光效编程实战
  • 别再只调sklearn了!深入拆解线性回归:从损失函数MSE到评估指标R²的数学原理与Python实现
  • 如何用IronyModManager彻底掌控Paradox游戏模组生态
  • Python技术周刊 2026年第14周
  • JiYuTrainer:如何破解极域电子教室控制限制实现学习自由?
  • Arduino蓝牙遥控小车:从L298N电机驱动到HC-05模块的完整实现
  • 2026 年晋城装修行业分析及口碑企业推荐 - 商业新知
  • HoneySelect2终极汉化与MOD整合补丁:5分钟自动化配置完整指南
  • 植物大战僵尸python代码
  • Zotero终极美化插件:打造专业高效的文献管理界面
  • 项目介绍 MATLAB实现基于LSTM-Attention长短期记忆网络(LSTM)结合注意力机制进行多变量时序预测(含模型描述及部分示例代码)专栏近期有大量优惠 还请多多点一下关注 加油 谢谢 你的
  • 3步解锁加密音乐:Unlock-Music浏览器工具完全指南
  • 如何快速掌握DLSS Swapper:新手3分钟游戏性能优化终极指南
  • 从被动矩阵LED点阵逆向工程到驱动算法优化:嵌入式显示系统设计解析
  • 自制木制SMD焊接夹具:低成本实现PCB与贴片元件精准固定
  • 国产影像测量仪技术升级实录:从手动到全自动,这家厂家是如何做到高精度+高效率的?​ - 品牌推荐大师
  • 2026孝感各区黄金上门回收价格表出炉,述姗黄金回收透明无套路 - 余生黄金回收
  • 2026年企业数字营销转型难题解析:郑州GEO优化公司多维对比梳理 - 兔兔不是荼荼
  • 三步快速掌握小说下载器:200+网站免费离线阅读终极指南