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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值