cx oracle 捕获异常,Cx-Oracle的使用及常见错误处理,cxOracle,报错

2023-11-07 15:10

本文主要是介绍cx oracle 捕获异常,Cx-Oracle的使用及常见错误处理,cxOracle,报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python操作Oracle数据库不如操作MySQL方便,使用pymysql可以很容易的连接上MySQL数据库,但是使用cx-Oracle连接Oracle数据库需要注意python解释器、cx-Oracle以及Oracle Client位数版本要一致。

1、统一python、cx_oracle、Oracle Client位数

检查python版本:在CMD通过python命令查看python版本

8e44fd4d72a3197fccfa82207b5ee96a.png

选择合适的 cx-Oracle库:可以在这里找到合适的版本

https://www.lfd.uci.edu/~gohlke/pythonlibs/#cx_oracle​

ddd871c4a9255c5d14cb906ffa65ae97.png

d460a8903911fe76a71cefa388627167.png

2、把DLL文件放到python解释器的同级目录下

把oci.dll、oraocci11.dll、oraociei11.dll这三个文件复制到python.exe同级目录下(11不是固定的,根据下载的版本,可能是oraocci11.dll等其他)

06ef0cd8dee4b4e4c1c57dd40ad716fa.png

常见报错:

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并重新安装后,即可

15aea224ff8de69f85bd14bbb56806d2.png

DPI-1072: the Oracle Client library version is unsupported

Oracle Client 版本不匹配,选择合适的版本和位数的Client,然后把需要的DLL文件复制到python.exe文件下。

如果只复制到python根目录下不能解决问题,可以尝试把文件同时复制到.

\lib\site-packages

文件夹下

其他疑难杂症

配置下client的环境变量

7ff59a37fb5f89be35f76a75104d6524.png

TNS_ADMIN: instant-client的安装目录

path: instant-client的安装目录

咱也不知道这个环境变量有啥用,如果实在没招了,试下这个,万一好使呢……

这篇关于cx oracle 捕获异常,Cx-Oracle的使用及常见错误处理,cxOracle,报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/364476

相关文章

Swagger2与Springdoc集成与使用详解

《Swagger2与Springdoc集成与使用详解》:本文主要介绍Swagger2与Springdoc集成与使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1. 依赖配置2. 基础配置2.1 启用 Springdoc2.2 自定义 OpenAPI 信息3.

IDEA实现回退提交的git代码(四种常见场景)

《IDEA实现回退提交的git代码(四种常见场景)》:本文主要介绍IDEA实现回退提交的git代码(四种常见场景),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.已提交commit,还未push到远端(Undo Commit)2.已提交commit并push到

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

Golang interface{}的具体使用

《Golanginterface{}的具体使用》interface{}是Go中可以表示任意类型的空接口,本文主要介绍了Golanginterface{}的具体使用,具有一定的参考价值,感兴趣的可以了... 目录一、什么是 interface{}?定义形China编程式:二、interface{} 有什么特别的?✅

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

PyTorch中cdist和sum函数使用示例详解

《PyTorch中cdist和sum函数使用示例详解》torch.cdist是PyTorch中用于计算**两个张量之间的成对距离(pairwisedistance)**的函数,常用于点云处理、图神经网... 目录基本语法输出示例1. 简单的 2D 欧几里得距离2. 批量形式(3D Tensor)3. 使用不

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR