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