允许关闭数据库时关闭cx_Oracle连接
作者:互联网
数据库启动后,以下cx_Oracle代码可以正常工作:
#!C:\Python27
import cx_Oracle
try:
conn = cx_Oracle.connect("scott/tiger@oracle")
try:
curs = conn.cursor()
curs.execute("SELECT dummy FROM sys.dual")
print curs.fetchone()[0]
finally:
curs.close()
finally:
conn.close()
但是,如果在运行此脚本时数据库恰好关闭,则会引发NameError:
Traceback (most recent call last):
File "C:\Users\ArtMetzer\Documents\Code\Python\db_conn_test.py", line 14, in <module>
conn.close()
NameError: name 'conn' is not defined
这对我来说很有意义:cx_Oracle无法实例化连接,因此从未设置变量conn,因此没有close()方法.
在Python中,最好的方法是确保您的数据库连接关闭,同时仍能正常处理已关闭的数据库的情况?
对我而言,执行以下操作似乎是一个巨大的麻烦:
finally:
try:
conn.close()
except NameError:
pass
解决方法:
您可以尝试将conn初始化为类似None的东西,然后在finally块中对其进行测试.之所以可行,是因为将连接设置为其他位置的唯一位置是打开连接时的位置.如此打开表示未打开,“无”表示未打开:
#!C:\Python27
import cx_Oracle
conn = None
try:
conn = cx_Oracle.connect("scott/tiger@oracle")
try:
curs = conn.cursor()
curs.execute("SELECT dummy FROM sys.dual")
print curs.fetchone()[0]
finally:
curs.close()
finally:
if conn is not None:
conn.close()
标签:try-finally,nameerror,cx-oracle,database-connection,python 来源: https://codeday.me/bug/20191102/1994494.html