Python3操作oracle数据库及遇到的报错
2017-10-18 05:27
447 查看
首先下载及安装cx_Oracle:
下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/
安装:pip3.6 install E:\Python36\Scripts\cx_Oracle-6.0.2-cp36-cp36m-win_amd64.whl
编写一个简单的测试代码:
报错内容如下:
conn = ora.connect('temp/admin@localhost: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,再次运行,问题解决。
下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/
安装: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/admin@localhost: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/admin@localhost: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,再次运行,问题解决。
相关文章推荐
- Python操作Oracle数据库时出现ImportError: libclntsh.so.10.1: cannot open shared object file: No such file or
- python splinter操作chrome时遇到的驱动问题
- QT 操作oracle数据库遇到的问题
- Python使用cx_Oracle模块操作Oracle数据库详解
- Python操作Oracle数据库的简单方法和封装类实例
- QT 操作oracle数据库遇到的问题
- Python操作Oracle数据库
- Python编程实战之Oracle数据库操作示例
- python操作oracle数据库环境配置
- Python调用SQLPlus来操作和解析Oracle数据库的方法
- python操作mongoDB的时候遇到问题,find()结果无法保存
- Python实战之Oracle数据库操作
- Python实战之Oracle数据库操作
- Python使用cx_Oracle模块连接操作Oracle数据库
- Python操作Oracle数据库
- 随笔记:如何使用Python连接(/操作)Oracle数据库(Windows平台下)
- Python操作Oracle数据库
- Python调用SQLPlus来操作和解析Oracle数据库的方法
- python操作oracle数据库的另类方法
- 【DRP】Oracle数据库安装遇到的问题及简单操作