专栏首页python3Python3操作oracle数据库及遇

Python3操作oracle数据库及遇

首先下载及安装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

编写一个简单的测试代码:

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,再次运行,问题解决。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python的常见矩阵运算

    python的numpy库提供矩阵运算的功能,因此我们在需要矩阵运算的时候,需要导入numpy的包。

    用户2398817
  • 常见矩阵运算Python

    python的numpy库提供矩阵运算的功能,因此我们在需要矩阵运算的时候,需要导入numpy的包。

    用户2398817
  • VRRPv2、VRRPv3、VRRPE详

    当Master/Backup选举完毕后,Master路由器会隔一段时间发送一个VRRP组播报文,以通知Backup路由器我主路由器是正常工作状态,当一个Bac...

    用户2398817
  • Java 语音识别404?

    https://aai.qcloud.com/asr/v1/1256605693?callback_url= http://test.qq.com/rec_ca...

    用户2177354
  • bootstrap scollspy 滚动监听

    <!doctype html> <html> <head> <meta charset="utf-8"> <title>联想控股</title> <m...

    用户5760343
  • React 性能调优——PureComponent 篇

    WEBJ2EE
  • 一桩VIM引发的血案

    在使用vim的时候,如果打开的小文件,没啥问题,如果打开的超大类型的文件,那么就会引发巨大的风险,轻则内存使用爆炸,重则引发操作系统oom。

    SRE运维实践
  • 03_多协程爬取糗事百科热图

    今天在使用正则表达式时未能解决实际问题,于是使用bs4库完成匹配,通过反复测试,最终解决了实际的问题,加深了对bs4.BeautifulSoup模块的理解。

    用户2398817
  • python 智能提示

    按图走就可以了   亲测

    用户2398817
  • vue2.0使用swiper

    源自:http://blog.csdn.net/susuzhe123/article/details/69525609

    余生

扫码关注云+社区

领取腾讯云代金券