如题,找了好多帖子没有找到办法! 使用 try: except: 无法捕获异常,程序直接退出,我代码如下:
try:
db = pymssql.connect(host='127.0.0.1',user='sa',password='sa',database='temp',charset='cp936')
state=0
except pymssql.OperationalError:
pass
except TypeError:
pass
#传参错误
except pymssql.InterfaceError:
pass
except Exception as e:
traceback.print_exc()
print(e)
cursor = db.cursor()
try:
# 执行 sql 语句
sql="""SELECT * FROM xm_info"""
cursor.execute(sql) # 如果执行到此处发生网络断开,程序直接异常退出,下面异常捕获无数据
result = cursor.fetchone()
cursor.execute(sql2) # 如果执行到此处发生网络断开,程序直接异常退出,下面异常捕获无数据
result2 = cursor.fetchone()
cursor.execute(sql3) # 如果执行到此处发生网络断开,程序直接异常退出,下面异常捕获无数据
result3 = cursor.fetchone()
except:
# 输出异常信息,此处如果网络断开无法捕获异常
traceback.print_exc()
# 如果发生异常,则回滚
db.rollback()
finally:
# 最终关闭数据库连接
db.close()