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

  1. #!/usr/bin/env python
  2. # -*-coding:UTF-8-*-

  3. import sys
  4. import cx_Oracle

  5. ora_ip="10.0.20.47"
  6. ora_port="1521"
  7. SERVICE_NAME="YUYIZHI"
  8. ora_dsn=cx_Oracle.makedsn(ora_ip,ora_port,SERVICE_NAME)
  9. print "the dsn is ",ora_dsn
  10. connection = cx_Oracle.Connection(u"user",u"passwd",ora_dsn)
  11. cursor = connection.cursor()

  12. try:
  13.     cursor.execute("select 1 / 0 from dual")
  14. except cx_Oracle.DatabaseError, exc:
  15.     error, = exc.args
  16.     print >> sys.stderr, "Oracle-Error-Code:", error.code
  17.     print >> sys.stderr, "Oracle-Error-Message:", error.message


  18. the dsn is  (DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.0.20.47)(PORT=1521)))(CONNECT_DATA=(SID=YUYIZHI)))
  19. Traceback (most recent call last):
  20.   File "1.py", line 17, in ?
  21.     cursor.execute("select 1 / 0 from dual")
  22. 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