- 浏览: 497046 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (258)
- 0-中医 (83)
- 1-工作 (4)
- 2-生活 (17)
- 3-其他 (3)
- oracle_dev (5)
- oracle_dba (35)
- ebs_gl (1)
- ebs_ap (0)
- ebs_po (0)
- ebs_hr_people (0)
- ebs_hr_payroll (0)
- java (12)
- javaScript (7)
- JSP2.0 (4)
- springMVC (3)
- spring (4)
- iBatis (5)
- Hibernate (3)
- tomcat (2)
- linux (13)
- 网络 (3)
- python (25)
- Django (11)
- z-技术 (13)
- PHPCMS (0)
最新评论
-
bo521dai:
Bravo. contains everything.
Oracle调优总结 -
yangxiutian:
固态硬盘是什么东东,既然对硬件有约束,我想推广难啊,除非若干年 ...
未来操作系统(组图) -
showzh:
...
listener.ora 、sqlnet.ora 、tnsnames.ora的关系以及手工配置举例 -
489687009:
我特别想问一下楼主,现在有了框架后,jsp2.0还有用武之地吗 ...
JSP2.0入门 -
liuzl121:
你好 我刚学java,我想请教下这个SignonControl ...
log4j详尽配置实战(for spring)
--===========================================================================
我的实践过程:
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}
来源"岁月联盟"
完成。
我的实践过程:
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}
来源"岁月联盟"
完成。
发表评论
-
Django之Apache/mod_python安装及HelloWorld
2009-11-12 11:31 1856from: http://hideto.iteye.com/b ... -
一个python写的简单的代理服务器
2009-08-02 22:14 4575from: http://dream-people.iteye ... -
Python模块包中__init__.py文件的作用
2009-07-29 17:03 1300from:http://www.iteye.com/topic ... -
Google App Engine 开发人员指南
2009-07-27 13:31 962http://code.google.com/intl/zh- ... -
正则表达式
2009-07-27 12:28 931from: http://jamesblog.iteye.co ... -
Chinese Python User Group 中文Python用户组
2009-07-24 15:17 1168http://groups.google.com/group/ ... -
开心网查看朋友果实的小程序
2009-07-23 17:16 1450#!/usr/bin/env python # -* ... -
html 2 txt (完善中)
2009-07-23 17:01 1079import re filename=raw_input( ... -
英汉字典(有道)
2009-07-23 16:59 1271# fileName : dict.py import re ... -
Python学习计划
2009-07-22 10:37 3126from:http://jythoner.iteye.com/ ... -
python 资料共享(from javaeye )
2009-07-22 10:33 1043http://onlypython.group.iteye.c ... -
Python中的全局变量
2009-07-21 14:34 1201全局变量不符合参数传递的精神,所以,平时我很少使用,除非定义常 ... -
python教程:几行代码搞定python 设计模式
2009-07-21 13:55 1386# #!/usr/bin/env python # # ... -
python教程:异常处理
2009-07-21 13:52 1187#例子1 1. #coding:utf-8 2. ... -
PDFMiner
2009-07-20 10:07 6217PDFMiner Python PDF parse ... -
python 搜索 PDF文件 内容
2009-07-20 09:44 7205我想做个小东东,需要读取pdf文件的文本内容,然后搜索某个关键 ... -
数据库 API 参考
2009-07-02 09:19 847http://www.woodpecker.org.cn/ob ... -
python编程八荣八耻
2009-07-01 16:20 1069python编程八荣八耻 以动手实践为荣, 以只看不练为耻; ... -
python教程:分支、循环
2009-06-23 15:36 3481讲程序设计,不得不讲到顺序、分支、循环。 顺序就是从上到下运行 ... -
python 实践
2009-06-18 15:58 950http://www.iteye.com/topic/1011 ...
相关推荐
如果在安装过程中遇到问题,可以参考“故障排除”部分。cx_Oracle使用ODPI-C库来实现Python与Oracle数据库的连接。安装好cx_Oracle后,如果尚未安装Oracle客户端,那么还需要进行安装。cx_Oracle支持Oracle客户端...
3. 安装完成后,cx_Oracle模块将被添加到Python的site-packages目录中,这样你就可以在Python脚本中通过`import cx_Oracle`来使用它。 在使用cx_Oracle时,你需要了解以下核心概念和操作: - 连接数据库:使用`cx_...
Python中的cx_Oracle模块是用于连接和操作Oracle数据库的一个强大工具。它允许Python开发者通过标准的DB-API 2.0接口来与Oracle数据库进行交互,实现了包括查询、插入、更新和删除在内的各种数据库操作。 首先,要...
1. `cx_Oracle`源代码文件:这是cx_oracle模块的源代码,需要被编译并安装到Python的site-packages目录下。 2. Oracle Instant Client:Oracle数据库的轻量级客户端,包含连接Oracle数据库所需的库文件。离线包可能...
这个安装程序会将 cx_Oracle 库添加到你的 Python 安装中,使其可以识别并使用 cx_Oracle 模块。 4. 安装完成后,你可以通过 Python 提示符验证 cx_Oracle 是否正确安装。打开命令行,输入 `python` 进入 Python ...
本文实例讲述了python安装cx_Oracle模块常见问题与解决方法。分享给大家供大家参考,具体如下: 安装或使用cx_Oracle时,需要用到Oracel的链接库,如libclntsh.so.10.1,否则会有各种各样的错误信息。 安装Oracle ...
至此,cx_Oracle模块已经准备就绪,你可以使用Python进行Oracle数据库的连接和操作了。 总结一下,cx_Oracle离线安装在Linux环境下,需要安装cx_Oracle的RPM包,并配置Oracle Instant Client,包括基本连接库和SDK...
此外,cx_Oracle模块还提供了与消息队列操作相关的对象,比如MessageObjects、MessageTableObjects、MessageRowObjects和MessageQueryObjects,这些对象用于处理Oracle高级队列中的消息数据。 手册中提到的常量、...
如果在安装过程中遇到问题,可能是因为你的Python环境没有正确配置,或者cx_Oracle版本与Python 3.3不兼容。在这种情况下,你可能需要查找特定于Python 3.3的cx_Oracle版本,或者从源代码编译安装。 安装完成后,你...
在Python中与Oracle数据库进行交互,我们通常会借助cx_Oracle模块,这个模块是Python与Oracle数据库连接的重要桥梁。本文将详细介绍cx_Oracle模块的使用及其在Django框架下的应用。 cx_Oracle是Python的一个第三方...
`cx_Oracle` 是一个 Python 的数据库连接模块,它提供了与 Oracle 数据库交互的功能。`cx_Oracle-7.3.0.tar.gz` 是这个模块的最新版本,针对 Linux 操作系统。相比于常见的 `cx_Oracle-5.1.2` 版本,7.3.0 版本可能...
在Python编程环境中,如果你需要与Oracle数据库...当遇到oci.dll缺失的错误时,只需将压缩包中的文件放到合适的位置,并确保系统环境配置正确,就可以顺利地在web.py应用中使用cx_Oracle模块进行Oracle数据库的访问。
《Python链接Oracle数据库:cx_Oracle模块详解及安装指南》 在Python编程中,与Oracle数据库进行交互是一项常见的任务。为了实现这一目标,开发者通常会使用一个名为cx_Oracle的Python扩展模块。cx_Oracle是Python...
在安装cx_Oracle之前,确保你的Python环境已经准备好,并且了解了Python的安装和模块管理机制,例如使用pip进行安装。在没有pip的情况下,可以手动解压tar.gz文件,然后使用Python的setup.py脚本进行安装。 其次,...
在Python环境中安装cx_Oracle,通常可以通过pip命令完成。对于提供的whl文件,它是Python的二进制包,可以直接用pip安装: ```bash pip install cx_Oracle-8.0.0-cp35-cp35m-win_amd64.whl ``` 确保你的Python环境...
本文将详细讨论如何在Python 2.7环境下使用cx_Oracle模块,并着重讲解"cx_oracle python27 dll 文件"的重要性以及安装过程。 cx_Oracle是Python的一个第三方扩展,用于与Oracle数据库通信。它提供了一组Python接口...
cx_Oracle模块引入了一些特定的异常类,如`cx_Oracle.DatabaseError`、`cx_Oracle.IntegrityError`等,这些异常可以帮助我们定位和解决在数据库操作过程中遇到的问题。 总的来说,cx_Oracle是Python开发人员连接和...
例如,这个版本可能已经解决了前一版本中报告的一些问题,提高了与Oracle数据库的连接稳定性,或者增加了对某些特定Oracle功能的Python绑定。 在解压cx_Oracle-5.1.3.tar.gz后,你会得到一个名为cx_Oracle-5.1.3的...