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

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

 
阅读更多

安装或使用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,解压后,将其中的oraociei11.dll、oraocci11.dll、oci.dll文件复制到python安装目录的Lib/site-packages下,如 C:/Python26/Lib/site-packages,然后添加环境变量ORACLE_HOME,指向instant client目录。

 

二.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的包就没问题了。

 

转自:http://blog.csdn.net/huzhenwei/article/details/3946308

分享到:
评论

相关推荐

    Python连接oracle工具cx_Oracle官方文档

    如果在安装过程中遇到问题,可以参考“故障排除”部分。cx_Oracle使用ODPI-C库来实现Python与Oracle数据库的连接。安装好cx_Oracle后,如果尚未安装Oracle客户端,那么还需要进行安装。cx_Oracle支持Oracle客户端...

    python2.7_cx_oracle

    3. 安装完成后,cx_Oracle模块将被添加到Python的site-packages目录中,这样你就可以在Python脚本中通过`import cx_Oracle`来使用它。 在使用cx_Oracle时,你需要了解以下核心概念和操作: - 连接数据库:使用`cx_...

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

    Python中的cx_Oracle模块是用于连接和操作Oracle数据库的一个强大工具。它允许Python开发者通过标准的DB-API 2.0接口来与Oracle数据库进行交互,实现了包括查询、插入、更新和删除在内的各种数据库操作。 首先,要...

    cx_oracle离线安装.rar

    1. `cx_Oracle`源代码文件:这是cx_oracle模块的源代码,需要被编译并安装到Python的site-packages目录下。 2. Oracle Instant Client:Oracle数据库的轻量级客户端,包含连接Oracle数据库所需的库文件。离线包可能...

    python2.4.3和cx_Oracle 2.4安装包

    这个安装程序会将 cx_Oracle 库添加到你的 Python 安装中,使其可以识别并使用 cx_Oracle 模块。 4. 安装完成后,你可以通过 Python 提示符验证 cx_Oracle 是否正确安装。打开命令行,输入 `python` 进入 Python ...

    cx_Oracle离线安装包

    至此,cx_Oracle模块已经准备就绪,你可以使用Python进行Oracle数据库的连接和操作了。 总结一下,cx_Oracle离线安装在Linux环境下,需要安装cx_Oracle的RPM包,并配置Oracle Instant Client,包括基本连接库和SDK...

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

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

    cx_Oracle使用手册

    此外,cx_Oracle模块还提供了与消息队列操作相关的对象,比如MessageObjects、MessageTableObjects、MessageRowObjects和MessageQueryObjects,这些对象用于处理Oracle高级队列中的消息数据。 手册中提到的常量、...

    python3.3+cx_Oracle

    如果在安装过程中遇到问题,可能是因为你的Python环境没有正确配置,或者cx_Oracle版本与Python 3.3不兼容。在这种情况下,你可能需要查找特定于Python 3.3的cx_Oracle版本,或者从源代码编译安装。 安装完成后,你...

    cx_Oracle-7.3.0.tar.gz

    `cx_Oracle` 是一个 Python 的数据库连接模块,它提供了与 Oracle 数据库交互的功能。`cx_Oracle-7.3.0.tar.gz` 是这个模块的最新版本,针对 Linux 操作系统。相比于常见的 `cx_Oracle-5.1.2` 版本,7.3.0 版本可能...

    cx_Oracle-6.0b2-py3.6-win32.rar

    在Python中与Oracle数据库进行交互,我们通常会借助cx_Oracle模块,这个模块是Python与Oracle数据库连接的重要桥梁。本文将详细介绍cx_Oracle模块的使用及其在Django框架下的应用。 cx_Oracle是Python的一个第三方...

    cx_Oracle需要的oci.dll

    在Python编程环境中,如果你需要与Oracle数据库...当遇到oci.dll缺失的错误时,只需将压缩包中的文件放到合适的位置,并确保系统环境配置正确,就可以顺利地在web.py应用中使用cx_Oracle模块进行Oracle数据库的访问。

    Python库 | cx_Oracle-8.0.0-cp35-cp35m-win_amd64.whl

    在Python环境中安装cx_Oracle,通常可以通过pip命令完成。对于提供的whl文件,它是Python的二进制包,可以直接用pip安装: ```bash pip install cx_Oracle-8.0.0-cp35-cp35m-win_amd64.whl ``` 确保你的Python环境...

    cx_Oracle-5.1.2-11g.win32-py2.7.msi

    《Python链接Oracle数据库:cx_Oracle模块详解及安装指南》 在Python编程中,与Oracle数据库进行交互是一项常见的任务。为了实现这一目标,开发者通常会使用一个名为cx_Oracle的Python扩展模块。cx_Oracle是Python...

    cx_Oracle-5.1.3.tar.gz,oracle-instantclient11.2

    cx_Oracle是Python中用于与Oracle数据库交互的一个重要库,它提供了高效、稳定的接口,使得Python程序员可以方便地操作Oracle数据库。这里我们将深入探讨cx_Oracle-5.1.3.tar.gz这个压缩包以及与其相关的oracle-...

    cx_Oracle-5.2.1.tar.gz

    python 连接oracle用的 cx_oracle 模块,使用条件: 1. 首先安装python; 2. 安装oracle 客户端; 3. 安装 cx_oracle; 使用方法: #!/usr/bin/python import cx_Oracle 如果import没有问题,则说明安装成功。

    cx_oracle python27 dll 文件

    本文将详细讨论如何在Python 2.7环境下使用cx_Oracle模块,并着重讲解"cx_oracle python27 dll 文件"的重要性以及安装过程。 cx_Oracle是Python的一个第三方扩展,用于与Oracle数据库通信。它提供了一组Python接口...

    cx_Oracle-5.3-11g.win-amd64-py3.5-2.exe

    cx_Oracle模块引入了一些特定的异常类,如`cx_Oracle.DatabaseError`、`cx_Oracle.IntegrityError`等,这些异常可以帮助我们定位和解决在数据库操作过程中遇到的问题。 总的来说,cx_Oracle是Python开发人员连接和...

Global site tag (gtag.js) - Google Analytics