--===========================================================================

我的实践过程:

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 "", line 1, in

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安装cv-oracle时如何解决vc++的问题_python中cx_Oracle模块安装遇到的问题与解决方法...相关推荐

  1. python开发工具下所有软件都打不开_Python中pip/setup安装插件失败提示“pypi.python.org” 打不开的解决办法...

    经常在安装python安装包的时候提示安装失败,仔细查看失败原因,发现是网站pypi.python.org访问超时导致的,比如: Installed f:\fortest\python\lib\sit ...

  2. python导入模块快捷键_Python中的模块导入和读取键盘输入的方法

    导入模块 import 语句 想使用Python源文件,只需在另一个源文件里执行import语句,语法如下: ? 当解释器遇到import语句,如果模块在当前的搜索路径就会被导入. 搜索路径是一个解释 ...

  3. python jieba库下载_Python中jieba库安装步骤及失败原因解析

    Python 中 jieba 库安装步骤及失败原因解析 作为计算机小白, Python 的流行也让我蠢蠢欲动, 在请教计算机 专业同学后,开始上网课自学 Python 基础知识.今天老师简单的一 句话 ...

  4. python中importlib模块安装_Python中标准模块importlib详解

    Python中标准模块importlib详解 模块简介 Python提供了importlib包作为标准库的一部分.目的就是提供Python中import语句的实现(以及__import__函数).另外 ...

  5. python安装mysqldb模块_Python的MySQLdb模块安装

    在配置Django时,选择的是mysql数据库,要安装MySQLdb模块,不过安装过程中,遇到了很多errors,记录一下. 系统:ubuntu 11.10 mysql:直接apt-get安装的,ve ...

  6. python cx_oracle模块详解_Python使用cx_Oracle模块操作Oracle数据库详解

    这篇文章主要介绍了Python使用cx_Oracle模块操作Oracle数据库,结a合实例形式较为详细的分析了cx_Oracle模块的下载.安装及针对Orcle数据库的连接.执行SQL语句.存储过程等 ...

  7. 检查python是否安装成功的命令是_Python 中的pygame安装与配置教程详解

    安装软件环境及版本说明 OS: Win10 x 64 专业版 Python: 2.7 IDE: PyCharm Community 2018 1. 安装python 1)下载并安装python pyt ...

  8. python如何复制oracle数据_Python使用cx_Oracle模块将oracle中数据导出到csv文件的方法...

    本文实例讲述了Python使用cx_Oracle模块将oracle中数据导出到csv文件的方法.分享给大家供大家参考.具体实现方法如下: # Export Oracle database tables ...

  9. 如何判断python是否安装成功_python怎么判断模块安装完成

    要判断一个模块是否安装,非常简单,在终端中进入python,然后输入import 模块名.然后如果安装成功没有任何提示,直接显示下一 行交互,如果提示报错,那么就代表有问题. 例如 >>& ...

最新文章

  1. ASP.NET MVC (一)
  2. python 获取打包后二进制所在目录
  3. 现代密码学2.4--香农定理/Shannon Theorem:完美安全的充分必要条件
  4. shm_overview(7)
  5. Handler实现数据模板
  6. 软件系统架构~视点和视图
  7. Spark精华问答 | Spark和Hadoop的架构区别解读
  8. 清北学堂模拟赛d6t2 刀塔
  9. python的networkx 算法_python图算法库Networkx笔记 - Node and Centrality
  10. redux-actions入门
  11. 查询工商单位注册信息 平台
  12. 格式转换------用C#代码生成一个简单的PDF文件
  13. Markdown记录
  14. vba 冻结窗格_在VBA中进行调试-2A)代码窗格(F7)
  15. 几何光学学习笔记(30)-6.5光通量和光亮度在光学系统中的传递、像面光照度
  16. ps命令查看进程详解
  17. 2K和XP的CMD命令教程(命令篇.要求置顶)
  18. 玩vr游戏的计算机配置要求,玩虚拟现实游戏,电脑配置必须强大如此
  19. 算法 - 快速排序(Quick_sort)
  20. 东财《施工技术与组织》综合作业

热门文章

  1. 10远程连接连接不上华为云_从云手机到云游戏,5G会在多大程度上改变我们的生活?...
  2. vim配置python开发环境_VIM插件管理及python开发环境配置
  3. hive load data inpath 空目录_Hive内部表 | 每日五分钟学大数据
  4. 【阿里云总监课第四期】时髦的云原生应用怎么写?
  5. WPF:Graphics图表--EncodingAndersonDecoding图像编解码(2)
  6. 非常好!!!---bash转义序列笔记---打印语句printf用法【转】
  7. 工作中搜索页面搜索记录功能的封装(存储到本地)
  8. 一个漂亮的 PlaceHolder
  9. Xamarin.IOS中MvvmCross的plugin使用方式
  10. python学习之路基础篇(第四篇)