Python捕获sqlalchemy异常内的pymysql异常

44 篇文章 0 订阅

在使用pymysql时,我们可以捕获异常代码和异常信息来定位sql执行的问题,例如如果删除一张本就不存在的表,会报错

import pymysql
...
try:
	cursor.execute("DROP TABLE game")
except pymysql.err.OperationalError as e:
	print(e)
	code, msg = e.args
pymysql.err.OperationalError(1051, "Unknown table 'web_data.game'")

但是如果我们使用sqlalchemy来执行sql

import sqlalchemy
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

engine = create_engine('mysql+pymysql://...........)
Session = sessionmaker(bind=engine)
session = Session()
try:
	session.execute("DROP TABLE game")
except Exception as e:
	print(e)
OperationalError('(pymysql.err.OperationalError) (1051, "Unknown table \'game\'")')

我们发现在pymysql.err.OperationalError上又包裹了一个OperationalError,而OperationalError是sqlalchemy的错误,所以此时如果继续使用pymysql.err.OperationalError就捕获不到该异常
需要改为:

...
try:
	session.execute("DROP TABLE game")
except sqlalchemy.exc.OperationalError as e:
	code, msg = e.orig.args[0]

注意,使用e.orig才能够获取到异常内的pymysql.err.OperationalError信息

参考:https://stackoverflow.com/a/54334125

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值