博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python连接oracle数据库
阅读量:5846 次
发布时间:2019-06-18

本文共 1155 字,大约阅读时间需要 3 分钟。

step1:下载cx_Oracle模块,cmd--pip install cx_Oracle

step2:

1 import cx_Oracle                                                #引用模块cx_Oracle2 conn=cx_Oracle.connect('truck/******@10.74.**.**:****/****') #连接数据库 3 c=conn.cursor() #获取cursor 4 x=c.execute('select sysdate from dual') #使用cursor进行各种操作 5 x.fetchone() 6 c.close() #关闭cursor 7 conn.close() #关闭连接

报错:cx_Oracle.DatabaseError: DPI-1047: 64-bit Oracle Client library cannot be loaded: "The specified module could not be found".

原因:本机装的Python、cx_Oracle都是64位的,Navicat连接的Oracle instantclient版本为32位的,所以连接报错。

解决方案:下载64位 instantclient---   或者  http://www.oracle.com/technetwork/database/database-technologies/instant-client/downloads/index.html

操作:下载结束后,解压至  Navicat根目录,添加环境变量,重启连接脚本。

报错:listener does not currently know of service requested in connect descriptor

原因:参数理解错误

#conn=cx_Oracle.connect(‘用户名/密码@主机ip地址:端口号/Service Name(SID)') conn=cx_Oracle.connect('truck/******@10.74.**.**:****/****')

正确输入参数之后,数据库连接成功

 Python连接Oracle如果有中文,可能会出乱码,可通过以下方法解决

1 import os2 os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

同时,在Python脚本中,添加一行代码

# -*- coding: utf-8 -*-

 

转载于:https://www.cnblogs.com/cyxiaer/p/9396861.html

你可能感兴趣的文章
PCM数据格式,多少字节算一帧
查看>>
Spring Data JPA
查看>>
KACK的处理方法
查看>>
POJ3438 ZOJ2886 UVALive3822 Look and Say【数列】
查看>>
IE6的height小BUG
查看>>
说说IUnitOfWork~DbContext对象的创建应该向BLL层公开
查看>>
强制卸载kernel
查看>>
web渗透测试中WAF绕过讲解(二)基于HTTP协议绕过
查看>>
【CSON原创】CSS的障眼法:利用border实现图片的翻转
查看>>
oracle:plsql学习总结(oracle database 10g sql 开发指南)
查看>>
〔转〕Word域的应用和详解2_等式和公式域
查看>>
FZU 1502 Letter Deletion
查看>>
寄存器是什么 有什么作用
查看>>
转载 《Python爬虫学习系列教程》学习笔记
查看>>
NGUI的输入框制作(attach- input filed script的使用)
查看>>
[异常笔记] zookeeper集群启动异常: Cannot open channel to 2 at election address ……
查看>>
mysql 03
查看>>
NgDL:第三周:浅层NN
查看>>
OpenCV基于傅里叶变换进行文本的旋转校正
查看>>
Centreon 安装部署指南
查看>>