在使用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信息

本文探讨了在使用SQLAlchemy执行SQL时如何正确捕获并处理来自底层PyMySQL的异常,特别是在尝试删除不存在的表时。通过示例说明如何访问原始的PyMySQL异常信息。
1306

被折叠的 条评论
为什么被折叠?



