【Python】cx_oracle报错"DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: "

记得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)下。再次运行脚本,问题解决。

 

参考

  1. https://www.cnblogs.com/yangtou45du/p/9066358.html
  2. https://www.cnblogs.com/rn-05181226-rw/p/9447318.html
  3. https://blog.csdn.net/jiaken/article/details/79537657

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值