• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
百里丶落云
Gee,gee,baby,baby
            管理     
Python连接oracle数据库 例子一

 

 

 

 

 

 

 

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

step2:

复制代码
1 import cx_Oracle                                                #引用模块cx_Oracle
2 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://jvniu.jb51.net:81/201708/tools/instantclientx64_jb51.rar   或者  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 os
2 os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

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

# -*- coding: utf-8 -*-
年与时驰,意与日去,遂成枯落, 多不接世,悲守穷庐,将复何及。
posted on 2019-09-20 15:27  百里丶落云  阅读(1377)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3