Python3操作oracle数据库及遇到的报错

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python3操作oracle数据库及遇到的报错相关的知识,希望对你有一定的参考价值。

首先下载及安装cx_Oracle:
下载地址:
 安装:pip3.6 install E:\Python36\Scripts\cx_Oracle-6.0.2-cp36-cp36m-win_amd64.whl
 
 编写一个简单的测试代码:
import cx_Oracle as ora
# print(ora.version)
# 打开数据库连接
# conn = ora.connect("temp", "admin", "localhost:1521/orcl")
conn = ora.connect(‘temp/[email protected]:1521/orcl‘)
# 使用cursor()方法获取操作游标
cr = conn.cursor()sql = ‘‘‘
    select empno, ename, job, mgr, hiredate, sal, comm, deptno, sal+comm as a from emp
    WHERE deptno = :did
    ‘‘‘
cr.execute(sql,did = 30)
for i in cr:
    print(i)
# 关闭数据库连接
cr.close()
# 提交操作
#conn.commit()
conn.close()

运行代码,结果居然报错了!


报错内容如下:

conn = ora.connect(‘temp/[email protected]:1521/orcl‘)

UnicodeDecodeError: ‘utf-8‘ codec can‘t decode bytes in position 82-83: invalid continuation byte

一看就是一个字符编码的问题,但无论怎么设置都不能解决问题,在网上也找了类似的错误解决方案,都不能得到解决。

在百度看见一条说系统、oracle客户端、Python要同样是64位或者32位的,不然就报这个错误。

我的电脑系统是64位、Python也是64位的,但是oracle客户端确是32的,这是因为我要连接plsql developer,以前的版本不支持64的客户端。

这样我删除了32位的oracle客户端,重新安装了64位的客户端,结果发现还是会报同样的错误,我就郁闷了,突然灵光一闪环境变量没有配,Python是需要oci.dll文件的,我就在环境变量中做了一下配置:

e:\Oracle\Instant Client\bin

重启IDE,再次运行,问题解决。

以上是关于Python3操作oracle数据库及遇到的报错的主要内容,如果未能解决你的问题,请参考以下文章

20170514002Oracle 11g R2安装过程中遇到的报错及解决办法

跑Vue项目遇到的报错及解决方法

跑Vue项目遇到的报错及解决方法

跑Vue项目遇到的报错及解决方法

跑Vue项目遇到的报错及解决方法

解决连接oracle报错 尝试加载Oracle客户端库时引发BadImageFomatException。如果在安装64位Oracle客户端组件的情况下以32位模式运行,将出现此问题的报错。