Python使用cx_Oracle模块操作Oracle数据库详解


Posted in Python onMay 07, 2018

本文实例讲述了Python使用cx_Oracle模块操作Oracle数据库。分享给大家供大家参考,具体如下:

ORACLE_SID参数,这个参数是操作系统中用到的,它是描述我们要默认连接的数据库实例,对于一个机器上有多个实例的情况下,要修改后才能通过 conn / as sysdba连接,因为这里用到了默认的实例名。

简而言之,打个比方,你的名字叫小明,但是你有很多外号。你父母叫你小明,但是朋友都叫你的外号。

这里你的父母就是oracle实例,小明就是sid,service name就是你的外号。

sid用于实例区分各个数据库,service name用于外部链接。 它们可能是不同的,要注意你得到的是哪个名字,合理使用,否则远程连接别的数据库可能出错。

前言

Python自带的模块中有很多操纵文件的。我们可以把文件的数据读出来,经过处理还可以将数据写入文件中。但是对于数据的管理和分析来说,数据库还是专业一些。如果Python能和数据库结合在一起,那么就能结合两种的优势,提高效率。

工作中使用的是Oracle数据库,Python有一个模块cx_Oracle可以与Oracle相连。要使用cx_Oracle,就要先下载。

1. 下载cx_Oracle

Python一个官方网站PyPI,上面有丰富的模块。cx_Oracle就可以在PyPI中下载。打开PyPI的网址https://pypi.python.org/pypi,在里面搜索cx_Oracle,即可找到该模块,其下载地址为http://cx-oracle.sourceforge.net/。当然也可以通过其它的途径下载。

下载之后就可以使用了。

2. 使用流程

简单的使用流程如下:

①.引用模块cx_Oracle
②.连接数据库
③.获取cursor
④.使用cursor进行各种操作
⑤.关闭cursor
⑥.关闭连接

下面是一个简单的例子:

cx_Oracle.connect("用户名 /  密码@ Oracle服务器IP  /  Oracle的SERVICE_NAME")

获得 Oracle的SERVICE_NAME:

su - oracle #切换至oracle用户

env | grep ORACLE #查询ORACLE的环境变量

ORACLE_SID=benguo # benguo就是SERVICE_NAME

import cx_Oracle                     #引用模块cx_Oracle
conn=cx_Oracle.connect('load/123456@localhost/ora11g')  #连接数据库
c=conn.cursor()                      #获取cursor
x=c.execute('select sysdate from dual')          #使用cursor进行各种操作
x.fetchone()
c.close()                         #关闭cursor
conn.close()                       #关闭连接

例子:

#coding:utf-8
import cx_Oracle
def main():
  conn = cx_Oracle.connect("zebra/zebra@192.168.0.113/benguo")
  cur =conn.cursor()
  r= cur.execute("select * from userinfo")
  print
  print r.fetchone()
if __name__ == '__main__':
  main()

3. 几种用法

Python对数据库的操作主要有2方面:一个是写数据,一个是读数据。这2个方面的实现可以通过SQL语句实现,也可以通过存储过程实现。所以cx_Oracle的主要用法有:

①. 执行SQL语句

②. 调用存储过程和函数。

4. 执行SQL语句

执行SQL语句很简单,从上面的例子就可以看出。使用cursor.execute即可执行。使用fetchone或fetchall即可将执行结果读出来。

下面一个例子是Insert语句,使用的变量绑定。

import cx_Oracle
conn=cx_Oracle.connect('load/123456@loaclhost/ora11g')
c=conn.cursor()
x=c.execute('insert into demo(v) values(:1)',['nice'])
conn.commit();
c.close()
conn.close()

变量绑定和Oracle的动态SQL一样,都是冒号将占位符,即代码中的:1,对变量的复制就是传入一个List,即代码中的['nice']。有多少个变量,list中就应该对应多少个值,数目要一致,否则会报错。

执行之后,可以使用连接的一个方法connect.commit(),将事务提交。

5. 调用存储过程和方法

直接上代码:

--存储过程代码:
CREATE OR REPLACE PROCEDURE P_DEMO(V1 IN VARCHAR2, V2 OUT VARCHAR2) IS
BEGIN
  V2 := V1;
END;
#Python代码:
import cx_Oracle
conn=cx_Oracle.connect('load/123456@localhost/ora11g')
c=conn.cursor()
str1='nice'
str2='  '#需要有值,即len(str2)>=len(str1)
x=c.callproc('p_demo',[str1,str2])
print(str2)
c.close()
conn.close()

调用存储过程使用的是cursor.callproc方法。上面的存储过程中,一个变量的值是OUT型的,在Python中,对OUT型的变量赋值,主要该变量的长度不能小于存储过程中的。

--函数代码:
CREATE OR REPLACE function F_DEMO(V1 VARCHAR2) RETURN VARCHAR2 IS
BEGIN
  RETURN V1;
END;
#Python代码:
import cx_Oracle
conn=cx_Oracle.connect('load/123456@localhost/ora11g')
c=conn.cursor()
str1='nice'
str2=c.callfunc('f_demo',cx_Oracle.STRING,[str1])
print(str2)
c.close()
conn.close()

调用函数使用的方法是cursor.callfunc。这个与调用存储过程不同之处在于,它需要指定传输参数的类型。

结束

通过cx_Oracle,可以是Python与Oracle数据库相互沟通,这样两者就可以长处互补。

比如,可以将Python当成一个数据收集的工具,可以从Web,从文件中获取数据,然后将这些数据保存到Oracle数据库中,在Oracle数据库上进行数据的进一步分析。

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python使用urllib模块开发的多线程豆瓣小站mp3下载器
Jan 16 Python
Python中的localtime()方法使用详解
May 22 Python
Python实现新浪博客备份的方法
Apr 27 Python
图文讲解选择排序算法的原理及在Python中的实现
May 04 Python
python3实现抓取网页资源的 N 种方法
May 02 Python
Ubuntu下使用python读取doc和docx文档的内容方法
May 08 Python
caffe binaryproto 与 npy相互转换的实例讲解
Jul 09 Python
python消费kafka数据批量插入到es的方法
Dec 27 Python
Python PO设计模式的具体使用
Aug 16 Python
python实现堆排序的实例讲解
Feb 21 Python
Python web如何在IIS发布应用过程解析
May 27 Python
Python使用Opencv实现边缘检测以及轮廓检测的实现
Dec 31 Python
Python代码缩进和测试模块示例详解
May 07 #Python
Python采集代理ip并判断是否可用和定时更新的方法
May 07 #Python
利用python的socket发送http(s)请求方法示例
May 07 #Python
Python爬虫抓取代理IP并检验可用性的实例
May 07 #Python
Python视频爬虫实现下载头条视频功能示例
May 07 #Python
十分钟利用Python制作属于你自己的个性logo
May 07 #Python
Redis使用watch完成秒杀抢购功能的代码
May 07 #Python
You might like
一篇入门的php Class 文章
2007/04/04 PHP
PHP实现新型冠状病毒疫情实时图的实例
2020/02/04 PHP
Gambit vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
js 发个判断字符串是否为符合标准的函数
2009/04/27 Javascript
artdialog的图片/标题以及关闭按钮不显示的解决方法
2013/06/27 Javascript
javascript中对Attr(dom中属性)的操作示例讲解
2013/12/02 Javascript
JQuery each()嵌套使用小结
2014/04/18 Javascript
html的DOM中document对象anchors集合用法实例
2015/01/21 Javascript
js实现发送验证码后的倒计时功能
2015/05/28 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
2015/06/24 Javascript
微信JSSDK上传图片
2015/08/23 Javascript
JS使用正则表达式实现关键字替换加粗功能示例
2016/08/03 Javascript
原生JS轮播图插件
2017/02/09 Javascript
详解webpack 多页面/入口支持&公共组件单独打包
2017/06/29 Javascript
基于dataset的使用和图片延时加载的实现方法
2017/12/11 Javascript
详解plotly.js 绘图库入门使用教程
2018/02/23 Javascript
基于javascript的无缝滚动动画1
2020/08/07 Javascript
vue实现移动端H5数字键盘组件使用详解
2020/08/25 Javascript
前端如何实现动画过渡效果
2021/02/05 Javascript
对Python中list的倒序索引和切片实例讲解
2018/11/15 Python
解决python xlrd无法读取excel文件的问题
2018/12/25 Python
python实现计数排序与桶排序实例代码
2019/03/28 Python
在Python中append以及extend返回None的例子
2019/07/20 Python
Python中zip()函数的解释和可视化(实例详解)
2020/02/16 Python
python实现企业微信定时发送文本消息的示例代码
2020/11/24 Python
python的setattr函数实例用法
2020/12/16 Python
CSS3网格的三个新特性详解
2014/04/04 HTML / CSS
使用 css3 实现圆形进度条的示例
2017/07/05 HTML / CSS
薇姿法国官网:Vichy法国
2021/01/28 全球购物
优秀学生干部个人的自我评价
2013/10/04 职场文书
合作经营协议书范本
2014/04/17 职场文书
食品流通安全承诺书
2014/05/22 职场文书
2014年学校党建工作汇报材料
2014/11/02 职场文书
少先队入队仪式主持词
2015/07/04 职场文书
Redis官方可视化工具RedisInsight安装使用教程
2022/04/19 Redis
Oracle查看表空间使用率以及爆满解决方案详解
2022/07/23 Oracle