记得2016年使用cx_Oracle类库访问Oracle时就出现过错误,近期在新电脑部署环境时又出现种种问题。现记录如下,供以后查阅。
遇到问题
使用pip命令安装cx_Oracle类库很顺利,当执行Python脚本对Oracle数据库进行访问时,一直出现"DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: "错误。
查阅了很多资料,尝试了一些方法,最终找到原因:电脑是64位系统、安装的Python3.6是64位、安装的Oracle客户端是32位。安装的Python版本位数一定要和Oracle客户端位数相同!否则就会出现上述报错。
查看Python版本位数方法:
查看Oracle客户端位数方法(有*32即为32位):
解决方法
原安装的Oracle客户端不用卸载、也不需添加修改任何环境变量,只需在Oracle官网下载对应的64位客户端即可:
https://www.oracle.com/database/technologies/instant-client/winx64-64-downloads.html
若下载的速度很慢、或者不能下载、或者下载完毕后突然出现“失败-已被禁止”提示,解决方案请参考:
https://blog.csdn.net/duanlianvip/article/details/103787983
将下载的instantclient-basic-xxxx文件中的oci.dll、oraociei12.dll、oraocci12.dll三个文件拷贝到python安装路径(例如:C:\Python36\Lib\site-packages)下。再次运行脚本,问题解决。
参考
- https://www.cnblogs.com/yangtou45du/p/9066358.html
- https://www.cnblogs.com/rn-05181226-rw/p/9447318.html
- https://blog.csdn.net/jiaken/article/details/79537657