zoukankan      html  css  js  c++  java
  • 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}

    来源"岁月联盟"


    完成。
  • 相关阅读:
    Linux 中改变主机名的 4 种方法
    如何成为优秀开发人员(一):怎样算是优秀的?
    Java中需要知道的关键字
    Java集合类常见的问题
    如何在 Linux 上复制文件/文件夹到远程系统?
    你还在 Select * 吗?
    技术人解决问题的思路
    如何创建编程语言,以及设计决策中的内容?
    Java内存溢出异常(下)
    如何在 Linux 中查看可用的网络接口
  • 原文地址:https://www.cnblogs.com/chenjianhong/p/4144999.html
Copyright © 2011-2022 走看看