`
fudehai001
  • 浏览: 487233 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

python中cx_Oracle模块安装遇到的问题与解决方法

阅读更多
--===========================================================================
我的实践过程:
1,将oci.dll文件(从oracle安装目录搜索)复制到python安装目录的Lib\site-packages下,如 C:\Python26\Lib\site-packages
2,添加环境变量:
  ORACLE_HOME = D:\oracle\ora92;
  PATH = .;%PATH%;D:\oracle\ora92\bin;
  LD_LIBRARY_PATH = %LD_LIBRARY_PATH%;D:\oracle\ora92;
that is all~
--============================================================================

安装或使用cx_Oracle时,需要用到Oracel的链接库,如libclntsh.so.10.1,否则会有各种各样的错误信息。

     安装Oracle Instant Client就可得到这个链接库,避免安装几百兆之巨的Oracle Client。

软件下载地址:

cx_Oracle的主页:http://cx-oracle.sourceforge.net/

必需的Oracle链接库的下载地址:http://www.oracle.com/technology/software/tech/oci/instantclient/index.html

常见的错误和解决方法:


一.win32二进制安装

在windows下安装cx_Oracle-5.0-10g.win32-py2.6.msi之后,导入时,报DLL加载失败的错误,如下:

IDLE 2.6.1     
>>> import cx_Oracle

Traceback (most recent call last):
  File "<pyshell#0>", line 1, in <module>
    import cx_Oracle
ImportError: DLL load failed: 找不到指定的程序。



解决方法:

从Oracle站点下载instantclient-basic-win32-10.2.0.4.zip,解压后,将其中的oci.dll文件复制到python安装目录的Lib\site-packages下,如 C:\Python26\Lib\site-packages

二.linux下二进制安装

在linux_x86_64下,安装cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm时报错。

[root@BJ-UPDATE-01 ~]# rpm -ivh cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm
error: Failed dependencies:
        libclntsh.so.10.1()(64bit) is needed by cx_Oracle-5.0.1-1.x86_64

解决方法:

参考http://cx-oracle.sourceforge.net/BUILD.txt

从Oracle站点下载basic-10.2.0.4.0-linux-x86_64.zip到/opt目录并解压,会看到libclntsh.so.10.1在/opt/instantclient_10_2目录中

设置环境变量

vi /root/.bash_profile

增加如下两行:

export ORACLE_HOME=/opt/instantclient_10_2
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME
运行source /root/.bash_profile使改动生效

建立此链接库的符号链接

cd $ORACLE_HOME

ln -s libclntsh.so.x.x libclntsh.so

重新安装cx_Oracle

注意加--nodeps参数,否则还会报上述错误

[root@BJ-UPDATE-01 ~]# rpm -ivh --nodeps cx_Oracle-5.0.1-10g-py24-1.x86_64.rpm

三.linux下源代码安装

设置环境变量及符号链接如上,在linux_x86_64下源代码安装,运行python setup.py build,编译时错误信息如下:

Connection.c:1169: 警告:语句不起作用
Connection.c:1171: 错误:‘udt_Connection’ 没有名为 ‘environment’ 的成员
Connection.c:1172: 警告:传递参数 1 (属于 ‘Environment_CheckForError’)时在不兼容的指针类型间转换
Connection.c:1172: 警告:传递参数 2 (属于 ‘Environment_CheckForError’)时在不兼容的指针类型间转换
Connection.c:1172: 错误:提供给函数 ‘Environment_CheckForError’ 的实参太多
Connection.c:1176: 错误:‘udt_Connection’ 没有名为 ‘sessionHandle’ 的成员

 
--=======================================================
如何在 Python环境下连接Oracle数据库

1.首先下载驱动:

(cx_Oracle),要注意一下版本,根据你的情况加以选择。

[信息来自"岁月联盟"]

2.安装:

Syue.com

执行exe安装程序就可以了,它会copy一个cx_Oracle.pyd到{PYTHON_HOME}\Lib\site-packages目录下。 "岁月联盟"提供

3.执行一段测试程序: [来源"岁月联盟"]

import cx_Oracle
con = cx_Oracle.connect( "xjtu_test", "37343734","xjtu.world")
cursor = con.cursor()
cursor.close()
con.close() ["岁月联盟"]

里边connect中的3个参数从左到右分别是:user, pass, TNS。
[Syue.com]

那个TNS可以用Oracle客户端工具中的Net Configuration Assistant来配置。

[www.Syue.com]

4.参考cx_Oracle API [内容来自"岁月联盟"]

好了,执行那段测试代码时你肯定遇到问题了,一般会有以下问题:

[信息来源"岁月联盟"]

【1】import cx_Oracle 时报告找不到OCI.DLL:

信息来自"岁月联盟"

到装了Oracle的机器上找一个,然后copy到{PYTHON_HOME}\Lib\site-packages目录下就可以了。 资源来自"岁月联盟"

【2】cx_Oracle.connect 时报告RuntimeError: Unable to acquire Oracle environment handle: 信息来自"岁月联盟"

这个问题相对比较麻烦,按以下步骤来解决:(可能不需要所有的步骤,我没有确认,不过把以下步骤都执行了,确实问题就解决了)

[资源来自"岁月联盟"]

首先,确认你是在控制台下边来执行这个python脚本的。而不是某些ide,例如:PyDev(它们似乎无法载入os的环境变量)。

"岁月联盟"提供

其实,在本机安装Oracle(只安客户端工具就可以了)。
Syue.com

最后,添加以下环境变量:(注:换成你自己的路径) 资源来自"岁月联盟"

ORACLE_HOME=D:\Oracle\Ora81
PATH=D:\Oracle\Ora81\bin;{your_other_paths}

来源"岁月联盟"


完成。  
分享到:
评论

相关推荐

    python安装cx_Oracle模块常见问题与解决方法

    本文实例讲述了python安装cx_Oracle模块常见问题与解决方法。分享给大家供大家参考,具体如下: 安装或使用cx_Oracle时,需要用到Oracel的链接库,如libclntsh.so.10.1,否则会有各种各样的错误信息。 安装Oracle ...

    Python使用cx_Oracle模块操作Oracle数据库详解

    主要介绍了Python使用cx_Oracle模块操作Oracle数据库,结合实例形式较为详细的分析了cx_Oracle模块的下载、安装及针对Oracle数据库的连接、执行SQL语句、存储过程等相关操作技巧,需要的朋友可以参考下

    cx_Oracle使用手册

    本文档为cx_Oracle库使用手册,cx_Oracle库为python连接Oracle的模块

    python 引入oracle模块

    win7环境 python2.7引入 oracle模块,里面有32和64位的文件, 如果引入引入cx_oracle报如下错误: cx_Oracle ImportError: DLL load failed: %1 不是有效的 Win32 应用程序。 请把压缩包对应的oci.dll放到%python_...

    Python使用cx_Oracle模块将oracle中数据导出到csv文件的方法

    主要介绍了Python使用cx_Oracle模块将oracle中数据导出到csv文件的方法,涉及Python中cx_Oracle模块与csv模块操作Oracle数据库及csv文件的相关技巧,需要的朋友可以参考下

    cx_oracle模块

    Python 是一种高度面向对象的语言,它易于学习并遵循良好的编程风格,即使那些没有经过正式软件工程培训的用户也可以使用它。由于易于学习,因此它无论是对于新手还是对于专家都具有很大的吸引力。

    python使用 cx_Oracle 模块进行查询操作示例

    主要介绍了python使用 cx_Oracle 模块进行查询操作,结合实例形式分析了Python使用cx_Oracle模块进行数据库的基本连接、查询、输出等相关操作技巧,需要的朋友可以参考下

    64位windows的cx_Oracle 模块——python3.5

    用于64位windows的cx_Oracle模块 python 3.5版的 最新!

    python_cx_oracle

    cx_oracle 模块详解 优点是能够使用 sqlplus的方法直接访问sql文件,不需要考虑打开/关闭连接,并且通过流向文件中写入还挺好用的

    python cx_Oracle模块的安装和使用详细介绍

    python cx_Oracle模块的安装 最近需要写一个数据迁移脚本,将单一Oracle中的数据迁移到MySQL Sharding集群,在linux下安装cx_Oracle感觉还是有一点麻烦的,整理一下,做个总结。 对于Oracle客户端,不只需要安装相应...

    Python如何应用cx_Oracle获取oracle中的clob字段问题

    最近在用Python编写连接数据库获取记录的脚本,其中用到了cx_Oracle模块。它的语法主要如下: cx_Oracle.connect('username','pwd','IP/HOSTNAME:PORT/TNSNAME') import cx_Oracle db1=cx_Oracle.connect('yang','...

    cx_Oracle需要的oci.dll

    用web.py连接oracle数据库时需要cx_Oracle模块,下载完模块后又发现报找不到oci.dll文件,我将这几个文件打包了,支持cx_Oracle11模块.

    解决python通过cx_Oracle模块连接Oracle乱码的问题

    今天小编就为大家分享一篇解决python通过cx_Oracle模块连接Oracle乱码的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

    Python笔记 之 cx_oracle和smtp模块简单应用

    在这个例子里将简单介绍使用cx_oracle模块和smtp模块来保存用户提交的数据并及时将处理结果反馈给用户

    cx_Oracle-5.1.2.tar.gz

    cx_Oracle 是一个 Python 扩展模块,通过使用所有数据库访问模块通用的数据库 API 来实现 Oracle 数据库的查询和更新。

Global site tag (gtag.js) - Google Analytics