Chinaunix
标题:
使用cx_Oracle链接oracle的问题
[打印本页]
作者:
zaibian
时间:
2010-06-10 14:17
标题:
使用cx_Oracle链接oracle的问题
脚本如下:
import sys
import cx_Oracle
ora_ip="10.1.3.1"
ora_port="1521"
SERVICE_NAME="ora10g"
ora_dsn=cx_Oracle.makedsn(ora_ip,ora_port,SERVICE_NAME)
print "the dsn is ",ora_dsn
connection = cx_Oracle.Connection(u"user",u"passwd",ora_dsn)
cursor = connection.cursor()
try:
cursor.execute("select 1 / 0 from dual")
except cx_Oracle.DatabaseError, exc:
error, = exc.args
print >> sys.stderr, "Oracle-Error-Code:", error.code
print >> sys.stderr, "Oracle-Error-Message:", error.message
执行的时候提示InterfaceError: Unable to acquire Oracle environment handle错误,在网上搜索的时候也没看到有具体的解决办法;现在使用的操作系统是xp的,在环境变量里已经配置好了ORACLE_HOME和path等变量,下载的cx_Oracle是python2.6,oracle10g的unicode的版本,不知哪位大侠能指导一番?
作者:
jjj137
时间:
2010-06-10 14:41
本帖最后由 jjj137 于 2010-06-10 14:43 编辑
执行到哪句出错的啊?是在控制台下运行的脚本么?
作者:
luffy.deng
时间:
2010-06-10 15:13
你是装了oracle客户端还是用的Oracle Instant Client?
作者:
zaibian
时间:
2010-06-10 16:11
to jjj137,print语句已经执行完了,执行到connect的时候在控制台打印了错误。
to luffy.deng 我的电脑上装的有oracle的客户端,我在lib\site-packages目录下放的也有oci.dll
作者:
luffy.deng
时间:
2010-06-10 20:03
回复
4#
zaibian
安装了oracle的客户端 注册表里就有了HOME信息 不需要设置环境变量,也不需要把oci.dll放到ilib\site-packages目录下,我在9i下从来没有遇到这个问题。检查一下print "the dsn is ",ora_dsn 输出的这个tns是不是正确,试一下用这个tns其他客户端sqlplus 、pl sql developer之类的能不能登录。另外你的客户端是不是一次安装成功的?多次安装可能会导致注册表里有无效的HOME信息 。
作者:
luffy.deng
时间:
2010-06-11 07:49
这个问题是由于OCIEnvNlsCreate调用失败产生的,网上的解决办法是给ORACLE_HOME目录加上network service用户的权限。
http://blog.sina.com.cn/s/blog_5421dfd20100fop1.html
作者:
atyu30
时间:
2010-08-06 14:14
#!/usr/bin/env python
# -*-coding:UTF-8-*-
import sys
import cx_Oracle
ora_ip="10.0.20.47"
ora_port="1521"
SERVICE_NAME="YUYIZHI"
ora_dsn=cx_Oracle.makedsn(ora_ip,ora_port,SERVICE_NAME)
print "the dsn is ",ora_dsn
connection = cx_Oracle.Connection(u"user",u"passwd",ora_dsn)
cursor = connection.cursor()
try:
cursor.execute("select 1 / 0 from dual")
except cx_Oracle.DatabaseError, exc:
error, = exc.args
print >> sys.stderr, "Oracle-Error-Code:", error.code
print >> sys.stderr, "Oracle-Error-Message:", error.message
the dsn is (DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.0.20.47)(PORT=1521)))(CONNECT_DATA=(SID=YUYIZHI)))
Traceback (most recent call last):
File "1.py", line 17, in ?
cursor.execute("select 1 / 0 from dual")
TypeError: expecting None or a string
复制代码
作者:
zaibian
时间:
2010-08-11 17:50
之前太忙,没来得及回复各位大侠的答复,我遇到的这个问题最后解决的办法是:去oracle网站重新下载了一个oracle10g的客户端实例,放到lib\site-packages目录下,能够正常使用。多谢各位!
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2