免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 10046 | 回复: 7
打印 上一主题 下一主题

使用cx_Oracle链接oracle的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-10 14:17 |只看该作者 |倒序浏览
脚本如下:
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的版本,不知哪位大侠能指导一番?

论坛徽章:
0
2 [报告]
发表于 2010-06-10 14:41 |只看该作者
本帖最后由 jjj137 于 2010-06-10 14:43 编辑

执行到哪句出错的啊?是在控制台下运行的脚本么?

论坛徽章:
0
3 [报告]
发表于 2010-06-10 15:13 |只看该作者
你是装了oracle客户端还是用的Oracle Instant Client?

论坛徽章:
0
4 [报告]
发表于 2010-06-10 16:11 |只看该作者
to jjj137,print语句已经执行完了,执行到connect的时候在控制台打印了错误。

to luffy.deng  我的电脑上装的有oracle的客户端,我在lib\site-packages目录下放的也有oci.dll

论坛徽章:
0
5 [报告]
发表于 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信息 。

论坛徽章:
0
6 [报告]
发表于 2010-06-11 07:49 |只看该作者
这个问题是由于OCIEnvNlsCreate调用失败产生的,网上的解决办法是给ORACLE_HOME目录加上network service用户的权限。
http://blog.sina.com.cn/s/blog_5421dfd20100fop1.html

论坛徽章:
0
7 [报告]
发表于 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
复制代码

论坛徽章:
0
8 [报告]
发表于 2010-08-11 17:50 |只看该作者
之前太忙,没来得及回复各位大侠的答复,我遇到的这个问题最后解决的办法是:去oracle网站重新下载了一个oracle10g的客户端实例,放到lib\site-packages目录下,能够正常使用。多谢各位!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP