python操作Oracle数据库不如操作MySQL方便,使用pymysql可以很容易的连接上MySQL数据库,但是使用cx-Oracle连接Oracle数据库需要注意python解释器、cx-Oracle以及Oracle Client位数版本要一致。
1、统一python、cx_oracle、Oracle Client位数
检查python版本:在CMD通过python命令查看python版本
选择合适的 cx-Oracle库:可以在这里找到合适的版本 https://www.lfd.uci.edu/~gohlke/pythonlibs/#cx_oracle
选择合适的Oracle Client:https://www.oracle.com/database/technologies/instant-client/downloads.html
2、把DLL文件放到python解释器的同级目录下
把oci.dll、oraocci11.dll、oraociei11.dll这三个文件复制到python.exe同级目录下(11不是固定的,根据下载的版本,可能是oraocci11.dll等其他)
常见报错:
ModuleNotFoundError: No module named 'cx_Oracle'
pip list查看已安装的库,明明看见有cx_oracle,但是却提示找不到模块,这时可以检查一下lib\site-packages下是不是真的还存在cx_oracle。
今天遇到这个报错,重新安装时提示模块已经在C:\Users\Administrator\AppData\Roaming\Python\Python37\site-packages,但是python是安装在C:\Users\Administrator\AppData\Local\Programs\Python\Python37-32路径下的。Baidu发现Roaming文件夹是系统运行后的缓存,在Roaming下有cx_oracle,但是在Local下没有cx_oracle,所以运行时报错找不到模块。
删除了Roaming下的cx_oracle并重新安装后,即可
DPI-1072: the Oracle Client library version is unsupported
Oracle Client 版本不匹配,选择合适的版本和位数的Client,然后把需要的DLL文件复制到python.exe文件下。
如果只复制到python根目录下不能解决问题,可以尝试把文件同时复制到.\lib\site-packages文件夹下
其他疑难杂症
配置下client的环境变量
TNS_ADMIN: instant-client的安装目录
path: instant-client的安装目录
咱也不知道这个环境变量有啥用,如果实在没招了,试下这个,万一好使呢……