数据库
首页 > 数据库> > 允许关闭数据库时关闭cx_Oracle连接

允许关闭数据库时关闭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