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

原创 2009年03月01日 00:44:00

     安装或使用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 

#5.0.3版本不用加--nodeps参数

 

三.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’ 的成员

 

解决方法:

5.0.3版本的未出现此错误,要注意ORACLE_HOME下要有include目录,这个目录中要有编译需要的源文件,源文件在Oracle Instant Client这个客户端中没有包含。我是从windows客户端的D:/oracle/product/10.2.0/client_1/oci/include这个目录中拷贝的。


四.import错误

>>> import cx_Oracle
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
ImportError: /usr/lib/oracle/10.2.0.4/client64//lib/libnnz10.so: cannot restore segment prot after reloc: Permission denied
>>> import cx_Oracle
Traceback (most recent call last):
  File "<stdin>", line 1, in ?
ImportError: /usr/lib/oracle/10.2.0.4/client64//lib/libclntsh.so.10.1: cannot restore segment prot after reloc: Permission denied
>>> import cx_Oracle
>>>

 

这是因为SELinux的限制,运行如下命令取消限制:

chcon -t texrel_shlib_t cd $ORACLE_HOME/libnnz10.so

chcon -t texrel_shlib_t cd $ORACLE_HOME/libclntsh.so.10.1


五、运行时错误

Traceback (most recent call last):
  File "oracle_conn.py", line 9, in ?
    connection = cx_Oracle.Connection(u"oracle/oracle123@CCIP")
cx_Oracle.InterfaceError: Unable to acquire Oracle environment handle

 

还是SELinux的限制,设置SELinux为disabled

   关掉selinux:  

   运行命令:  vim /etc/selinux/config
   将selinux=enforcing或permissive改成disabled
   运行命令:  setenforce 0

 

六. UNICODE的安装包有问题

 

Traceback (most recent call last):
  File "./oracle_conn.py", line 22, in ?
    folderIds=cursor.fetchmany(10)
cx_Oracle.DatabaseError: OCI-22061: Message 22061 not found; No message file for product=RDBMS, facility=OCI; arguments: [T

 

目前发现5.0.3版的包在执行SQL时会导致报错,不建议使用,换成非UNICODE的包就没问题了。

在windows10 64位下安装cx_oracle过程

最近在搞python,就想用它来访问oracle数据库,oracle官方是支持这种功能的,需要先下载对应版本的模块cx_oracle 下载地址:https://sourceforge.net/proj...
  • u013012406
  • u013012406
  • 2017年03月01日 10:45
  • 5589

linux环境下cx_Oracle的“ImportError: No module named cx_Oracle”

1.确认oracle-instantclient的basic、sqlplus、devel是否已按照成功 2./etc/profile 中是否配置正确(类似下列指令) ORACLE_HOME="/usr...
  • QZC295919009
  • QZC295919009
  • 2015年02月04日 10:51
  • 2284

python cx_Oracle模块的安装

 对于Oracle客户端,不只需要安装相应的python模块,还需要安装Oracle Client;还需要配置tnsnames.ora(当然也可以简单的通过host:port/instance访...
  • BabyFish13
  • BabyFish13
  • 2016年11月04日 12:02
  • 1305

Linux下连接oracle,出现cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: “

按照这里的步骤 将 oracle客户端安装到Linux上即可, https://oracle.github.io/odpi/doc/installation.html#linux...
  • Com_ma
  • Com_ma
  • 2017年11月21日 20:01
  • 3656

Python(Pycharm)连接Oracle数据库之cx_Oracle的使用(cx_Oracle在pyCharm中报错)

首先声明Python27+Windows32安装 我的电脑Windows版本是64位的,但是由于Pycharm中的pycrypto中使用了C语言的代码所以我在装Pycharm的时候装的是32位的,不需...
  • longlongValue
  • longlongValue
  • 2017年04月26日 12:47
  • 4363

cx_Oracle 报错:cx_Oracle.DatabaseError: DPI-1050: Oracle Client library must be at version 11.2

解决:从 https://pypi.python.org/pypi/cx_Oracle/5.3 下载低版本cx_Oracle版本 我是下载cx_Oracle-5.3-11g.win32-py3.6....
  • u014770372
  • u014770372
  • 2017年10月26日 17:29
  • 2040

python 连接oracle 报错 cx_Oracle.DatabaseErro

python 连接oracle 报错 cx_Oracle.DatabaseErro
  • joeyon
  • joeyon
  • 2014年08月29日 11:01
  • 3174

操作系统-----> 文件管理

1.   概述 1.1          文件和文件系统 从用户的角度,文件系统是操作系统的一个重要部分,它提供了与二级存储相关的资源抽象。文件系统特性集合主要有: 长期存在:用户注销不会消...
  • Com_ma
  • Com_ma
  • 2018年01月25日 09:28
  • 33

python-cx_oracle报错"DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: "

用python跑数据库脚本时,python报错"DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: " ...
  • yuzh_test
  • yuzh_test
  • 2017年12月26日 00:43
  • 1871

在 root 下执行 Oracle 程序时找不到 libclntsh.so.11.1 错误的解决办法。

在 root 下执行 Oracle 程序时找不到 libclntsh.so.11.1 错误的解决办法。 先确定 libclntsh.so.11.1 所在目录: [oracle@loca...
  • caixingyun
  • caixingyun
  • 2014年04月10日 11:22
  • 3373
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:python中cx_Oracle模块安装遇到的问题与解决方法
举报原因:
原因补充:

(最多只允许输入30个字)