python中cx_Oracle模块安装遇到的问题与解决方法_design321的博客-程序员宅基地

技术标签: python  Oracle  

转自:

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

安装或使用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的包就没问题了。


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/design321/article/details/16827911

智能推荐

安装MYSQL详细教程 版本:mysql-installer-community-5.7.16.0 免安装版本和安装版本出现错误的解决...-程序员宅基地

一、版本的选择 之前安装的Mysql,现在才来总结,好像有点晚,后台换系统了,现在从新装上Mysql,感觉好多坑,我是来踩坑,大家看到坑就别跳了,这样可以省点安装时间,这个折腾了两天,安装了好多个版本,终于安装好了,最终选择了最新的版本mysql-installer-community-5.7.16.0。以前是在其他软件网站下载的,但是觉得还是在官方网站下载比较靠谱。进入到M...

html+css+js实现选项卡切换-程序员宅基地

html+css+js选项卡效果如下:一、Html页面布局Html页面布局由三个按钮(input)和三个div组成,三个按钮中总有一个当前按钮(高亮),三个div放内容,三个div都是隐藏只有一个显示;

MFC Regular DLL封装窗体详细步骤-程序员宅基地

转自[url]http://blog.sina.com.cn/s/blog_4b2169480100d196.html[/url]vc6.0 环境下,将MFC Regular DLL封装窗体在里面。1. File->Projects->MFC AppWizard(dll)->输入RegularDLL;2. 选择Regular DLL using shared MFC DLL 和..._regular dll创建方法

约瑟夫环问题 C语言_报数被干掉-程序员宅基地

约瑟夫环问题,是一个经典的循环链表问题,题意是:已知 n 个人(分别用编号 1,2,3,…,n 表示)围坐在一张圆桌周围,从编号为 m的人开始顺时针报数,数到 n 的那个人被杀掉;他的下一个人又从 1 开始,还是顺时针开始报数,数到 n 的那个人又被杀;依次重复下去,直到圆桌上剩余一个人。//// Created by fish on 2020/3/21.//#include <st..._报数被干掉

SQL错误:无法绑定由多个部分组成的标识符“******”-程序员宅基地

问题描述:在做SQL实验检索由多个表特定条件限制情况下的数据项时,出现无法绑定由多个部分组成的标识符“*****”的错误,语法能够读通,但无法执行_无法绑定由多个部分组成的标识符

Acwing 基础课—基础算法—高精度加减乘除模板_acwing视频课资源 百度网盘-程序员宅基地

1 高精度加法题目链接https://www.acwing.com/problem/content/793/题目大意给定两个正整数,计算它们的和。位数100000#include<stdio.h>#include<iostream>#include<string>#include<algorithm>using namespace std;const int N = 100010;int A[N],B[N],C[N];// A+B=C_acwing视频课资源 百度网盘

随便推点

Spring Boot 2.2.6 源码之旅四十九@ConfigurationProperties原理二-程序员宅基地

Spring Boot 2.2.6 源码之旅四十九@ConfigurationProperties原理二简单流程ConfigurationPropertiesBindingPostProcessor的postProcessBeforeInitialization初始化之前处理ConfigurationPropertiesBean的getConfigurationPropertiesBean的get...

转:高等数学、线性代数、概率论数理统计书籍推荐-程序员宅基地

转:https://blog.csdn.net/Yahuvi/article/details/54692504导语最近在学习机器学习,发现需要恶补数学知识。总感觉国内大学的教材只适合考试,对数学知识的理解和运用不到位。现整理一些评价很高的书,总的来说较适合工科类的同学打基础和提高。高等数学入门《托马斯微积分》:直观易读,强调建模应用和技巧训练,重要的是不失数学上的完整性,工科使用应该相当不错。作者:芬尼 / 韦尔 / 焦尔当诺《普林斯顿微积分读本》:没看过,据说评价很高。 作者...

【解决方案】不能解决org.apache.commons:commons-math:2.2_org.apache.commons.math 下载-程序员宅基地

问题重现IntelliJ IDEA 刷新maven引用时,控制台提示下方的报错不能解决org.apache.commons:commons-math:2.2解决方案一、来到maven仓库,查询org/apache/commons文件夹下,找到commons-math文件夹下的2.2版本文件夹。发现该文件夹只有pom文件,没有项目所需的jar包。删除该文件夹,在IntelliJ IDEA内重新引入、下载即可完成引入操作。二、(一)是对笔者出现的问题进行修复的方案,._org.apache.commons.math 下载

埃及分数问题 IDA*-程序员宅基地

题意在古埃及,人们使用单位分数的和(即1/a,a是自然数)表示一切有理数。 例如,2/3=1/2+1/6,但不允许2/3=1/3+1/3,因为在加数中不允许有相同的。 对于一个分数a/b,表示方法有很多种,其中加数少的比加数多的好,如果加数个数相同,则最小的分数越大越好。 例如,19/45=1/5+1/6+1/18是最优方案。 输入整数a,b。分析本题可以用dfs回溯来求解。但是由于本题没有指...

Sleep() 和wait()的区别_wait()和sleep()的区别-程序员宅基地

Sleep() 和wait()的区别 Sleep()Sleep是线程类Thread 的方法,它是使当前线程暂时睡眠,可以放在任何位置。Sleep使用的时候,线程并不会放弃对象的使用权,所以在同步方法或同步块中使用sleep,一个线程访问时,其他的线程无法访问。sleep只是暂时休眠一定时间,时间到了之后,自动恢复运行,不需另外的线程唤醒.Wait()wait是使当前线程暂时放弃对..._wait()和sleep()的区别

弹出窗口 JS window.open()属性_window.open关闭弹窗属性-程序员宅基地

一. Window 对象转载地址:http://blog.csdn.net/vastskyjoe/article/details/4122104记录一下当笔记 1.Window 对象是 JavaScript 层级中的顶层对象。Window 对象代表一个浏览器窗口或一个框架。Window 对象会在 或 每次出现时被自动创建。二.open() 方法用于打开一_window.open关闭弹窗属性