`
longforfreedom
  • 浏览: 200150 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

用Python操作Oracle

阅读更多

 

Python作为一门易学易用且不失强大的语言, 国内外不乏用Python开发的从桌面系统到复杂大型系统的例子。但作为脚本语言中的一位著名代表,Python不仅可以用来取代Java、C++等系统 语言来开发复杂的大型系统,也可以被当作一种辅助工具用来做一些日常工作中的琐碎的事情,比如备份、生成测试数据、日志分析等等。本文将通过一些简单的例 子来演示如何使用Python来访问Oracle进行基本操作。需要说明的是本文并不会尝试对 Python 或Oracle进行全面的介绍或细致的讲解,只是通过一些简单实用的示例来,来演示如何使用Python操作Oracle。如果您希望深入了解请 Python及Python操作Oracle请参考本文最后给出的扩展阅读材料。

1 运行环境搭建

首先安装Python运行环境

下载地址: http://www.activestate.com/activepython/downloads

选择 2.6.x 版本下载 , 安装略过。

安装完成后在打开命令行 , 输入 python 进入 Python 交互环境如下图所示

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-20280.png

经典的Hello World:在交互环境中输入

>>>  print 'HELLO PYTHON'

回车后结果如下:

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-2403.png

类似我们在Java中访问数据库,需要使用相应数据库系统的 JDBC实现,Python中也有类似JDBC的一个统一接口,名为Python DB API,所以也需要相应的数据库系统的实现。Oracle的实现叫做cx_Oracle,所以需要先安装cx_Oracle

下载地址: http://cx-oracle.sourceforge.net/

安装略过,安装完成后在Python交互环境中输 入

import  cx_Oracle   # 注 意大小写

如下图所示:

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-13074.png

如果没有报错,证明安装成功。到这一步所需要的环境已经安装好 了。

其实Python 操作Oracle的流程与JDBC一样,首先创建连接,再获取游标对象,执行操作,获取结果,最后关闭连接,下面将通过一些例子来说明这个过程。

2 操作示例

下面将通过一些实际例子来演示如何操作Oracle

示例一:创建一个表 tb_user:

在交互环境中输入以下代码:


import cx_Oracle

#建立和数据库系统的连接

conn = cx_Oracle.connect('challenger/challenger@10.180.85.207/challenge')

#获取操作游标

cursor = conn.cursor()

#执行SQL,创建一个表

cursor.execute("""create table tb_user(id number, name varchar2(50),password varchar(50),primary key(id)) """)

#关闭连接,释放资源

cursor.close()

#执行完成,打印提示信息

print 'Completed!' 
 

 

示例二:在 tb_user 、插入单条数 据、插入多条数据

新建一个名为insert.py的文件写入以下内容:


#!/usr/bin/env python

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

###################################

# @author migle

# @date 2010-05-17

##################################

#在Oracle插入数据

#

##################################

import cx_Oracle

conn = cx_Oracle.connect('challenger/challenger@10.180.85.207/challenge')

cursor = conn.cursor()

 

#插入一条记录

cursor.execute("""insert into tb_user values(1,'admin','password')""");

#再插入一条数据

param={'id':2,'n':'admin','p':'password'}

cursor.execute('insert into tb_user values(:id,:n,:p)',param);

 

#一次插入多条数据,参数为字典列表形式

param=[{'id':3,'n':'admin','p':'password'},{'id':4,'n':'admin','p':'password'},{'id':5,'n':'admin','p':'password'}];

cursor.executemany('insert into tb_user values(:id,:n,:p)',param);

 

#再一次插入多条数据

param=[];

#生成5条插入数据,参数为元组列表形式

for i in range(6,11): # [6,7,8,9,10]

              param.append((i,'user'+str(i),'password'+str(i)))

#插入数据

cursor.executemany('insert into tb_user values(:1,:2,:3)',param);

 

cursor.close();

#提交更改

conn.commit();

conn.close();
 

保存后,打开命令行切换至insert.py所在目录

输入 :python insert.py 

运行插入数据脚本如下图所示

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-610.png

以上代码用了多种方式,共插入了10条数据,在sqlplus 中查看结果如下图所示

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-28807.png

示例三:查询。

查询和插入的流程基本类似,只是多了一个得到查询结果的步骤, 新建search.py文件,内容如下:


#!/usr/bin/env python

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

###################################

# @author migle

# @date 2010-05-17

##################################

#在Oracle中查询数据

#

##################################

import cx_Oracle

conn = cx_Oracle.connect('challenger/challenger@10.180.85.207/challenge')

cursor = conn.cursor()

#执行查询 语句

cursor.execute("""select * from tb_user""")

 

#获取一条记录

one = cursor.fetchone()

print '1: id:%s,name:%s,password:%s'%one;

 

#获取两条记录!!!注意游标已经到了第二条

two = cursor.fetchmany(2) 

print '2 and 3:',two[0],two[1]

 

#获取其余记录!!!注意游标已经到了第四条

three = cursor.fetchall(); 

for row in three:

              print row   #打印所有结果

             

print '条件查询'

cursor.prepare("""select * from tb_user where id <= :id""")

cursor.execute(None,{'id':5})

for row in cursor:  #相当于fetchall()

              print row

cursor.close();

conn.close();
 

运行search.py可以看到如下图所示的结果

C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-3660.png

实际上所有的主流数据库都有相应Python DB API的实现,如MySQL、PostgreSQL等,只需要安装相应的软件包即可,流程及操作接口都与cx_Oracle基本一致。

本文通过使用Python操作Oracle的基本 操作,如果您想对Python或用Python操作Oracle进行更进一步的了解,请看扩展阅读。

3 扩展阅读:

简单Python教程:

http://linux.chinaitlab.com/manual/Python_chinese/

Python cx_Oracle 5.0 新特性概述:

   http://www.oracle.com/technology/global/cn/pub/articles/tuininga-cx_oracle.html

精通Oracle+Python

http://www.oracle.com/technology/global/cn/pub/articles/prez-python-queries.html?_template=/ocom/print

用Python操作Mysql:

http://migle.iteye.com/blog/573092

 

 

分享到:
评论
2 楼 longforfreedom 2011-02-12  
darklinden 写道
非常感谢您的经验分享,但是图片资源貌似已经失效,望修复
<img style="border: medium none;" src="https://docs.google.com/File?id=ajgc24c9jh8n_966cqgx4kgt_b" alt="C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-3660.png" width="498" height="289">

谢谢提醒,
1 楼 darklinden 2010-12-01  
非常感谢您的经验分享,但是图片资源貌似已经失效,望修复
<img style="border: medium none;" src="https://docs.google.com/File?id=ajgc24c9jh8n_966cqgx4kgt_b" alt="C:\DOCUME~1\migle\LOCALS~1\Temp\ksohtml\wps_clip_image-3660.png" width="498" height="289">

相关推荐

    LTspice仿真:LDO电源电路学习与实践的利器

    内容概要:本文详细介绍了如何利用LTspice进行LDO(低压差线性稳压器)电源电路的仿真。首先讲解了如何导入LDO模型并配置仿真环境,接着深入探讨了瞬态分析、相位裕度、电源抑制比(PSRR)等关键仿真的具体步骤和注意事项。文中提供了多个实用的操作技巧,如通过调整补偿电容优化相位裕度,以及使用.step param命令批量测试不同参数的影响。此外,还分享了一些常见的仿真误区及其解决方法,帮助读者更好地理解和掌握LDO的设计与调试。 适合人群:电子工程专业学生、电源电路设计初学者、希望深入了解LDO特性的工程师。 使用场景及目标:适用于希望通过仿真工具提高LDO设计技能的人群。主要目标是掌握LDO的基本工作原理,学会使用LTspice进行各种类型的仿真分析,从而优化电路设计,确保系统的稳定性和性能。 其他说明:文章不仅提供详细的仿真步骤和技术细节,还附带了作者的实际经验和常见问题解决方案,使读者能够在实践中不断改进自己的设计思路。

    渝安集团员工职业发展通道设计方案.ppt

    渝安集团员工职业发展通道设计方案.ppt

    新能源电动汽车VCU与BMS的HIL硬件在环仿真技术及其模块化建模

    内容概要:本文详细介绍了新能源电动汽车中VCU(整车控制器)和BMS(电池管理系统)的HIL(硬件在环)仿真技术。首先阐述了整车建模的基础,包括电池、电机等关键部件的建模要点。接着分别解析了驾驶员模块、仪表模块、BCU整车控制器模块、MCU电机模块、TCU变速箱模块、BMS电池管理模块等多个子模块的功能和实现方式。最后强调了HIL仿真在电动汽车控制系统测试和优化中的重要性,特别是在降低成本和风险方面的作用。 适合人群:从事新能源汽车研发的技术人员,尤其是专注于VCU和BMS领域的工程师。 使用场景及目标:适用于需要深入了解电动汽车控制系统仿真技术的研发团队,在产品开发初期进行系统测试和优化,确保各子系统间的协同工作正常。 其他说明:文中提供了大量代码示例,帮助读者更好地理解和实践相关概念和技术细节。此外,还分享了一些实际项目中的经验和教训,如故障注入测试的具体应用场景等。

    如何应对一线人员春节后的离职潮.docx

    如何应对一线人员春节后的离职潮

    线性代数_GitHub_课件作业_教学辅助用途_1742837800.zip

    线性代数

    离职面谈表.xls

    离职面谈表.xls

    聚宽对接qmt大礼包,帮助你配置好交易实盘环境

    聚宽对接qmt大礼包,配备需要的全部软件:python3.9版本,qmt模拟安装包,pycharm安装包,talib包

    试用期转正表.xls

    试用期转正表.xls

    招聘数据分析.xls

    招聘数据分析.xls

    如何让新员工快速融入团队.docx

    如何让新员工快速融入团队

    电力电子仿真中并离网逆变器及无功补偿设备的控制策略与建模

    内容概要:本文详细介绍了并离网逆变器的两种主要控制策略——PQ控制和V/f控制,以及无功能量发生器(SVG)和有源电力滤波器(APF)的仿真模型。对于PQ控制,文章展示了如何将功率指令转化为电流指令,并强调了电网电压定向和限幅处理的重要性。V/f控制则用于离网模式,通过调节电压和频率来维持系统的稳定。SVG主要用于无功补偿,通过实时计算无功需求进行补偿。APF则专注于谐波检测和消除,利用自适应滤波器提高效率。此外,文中还提供了多个实用的小技巧,如仿真步长设置、模式切换时的前馈补偿等。 适合人群:从事电力电子仿真研究的技术人员,尤其是对逆变器控制策略感兴趣的工程师。 使用场景及目标:适用于需要深入理解和实现逆变器控制策略的研究项目,帮助工程师优化仿真模型,提升系统性能,确保仿真结果的准确性。 其他说明:文章不仅提供了详细的代码片段,还分享了许多实践经验,有助于读者避免常见错误,提高仿真成功率。

    Carsim与Simulink联合仿真中基于线性二自由度模型的卡尔曼滤波(KF)实现及优化

    内容概要:本文详细介绍了如何利用Carsim与Simulink进行联合仿真,通过线性二自由度模型和卡尔曼滤波(KF)来估计车辆的质心侧偏角和横摆角速度。首先搭建了联合仿真框架,Carsim提供车辆状态量,Simulink负责算法处理。文中展示了线性二自由度模型的状态方程及其参数设定,并深入探讨了KF的两种实现方式:S函数编程和Simulink内置模块。对于S函数实现,着重讲解了状态转移矩阵的动态更新以及噪声矩阵Q的调整策略,确保模型能够适应车速变化。而对于内置模块,则指出了其在灵活性方面的不足之处。此外,还讨论了联合仿真的配置要点,如数据接口同步、采样时间和信号处理等问题。 适合人群:从事车辆动力学研究、控制理论应用、自动化控制领域的工程师和技术人员。 使用场景及目标:适用于需要精确估计车辆质心侧偏角和横摆角速度的研究和开发项目,特别是在涉及ESP等主动安全系统的开发过程中。目标是提高估计精度,增强系统的鲁棒性和响应速度。 其他说明:文章提供了详细的代码片段和实践经验分享,帮助读者更好地理解和实施相关技术。建议在实际应用中根据具体需求选择合适的KF实现方式,并注意处理各种边界条件和异常情况。

    档案管理[03].pptx

    档案管理[03]

    风电与储能联合调频系统:基于Python的建模与优化

    内容概要:本文详细介绍了风电与储能联合调频系统的原理及其优化方法。首先解释了风电输出功率的波动性和对电网频率的影响,提出储能系统作为解决方案。文中展示了如何用Python生成风速数据并构建调频控制系统,重点讨论了PID控制器的设计以及SOC(荷电状态)管理策略。此外,还探讨了调频控制逻辑、硬件在环测试、风电功率预测模型(如LSTM)、调频效果验证方法及储能系统的物理限制等问题。最后强调了模型验证的重要性,提出了异常数据注入测试的方法。 适合人群:从事电力系统自动化、新能源发电及储能技术研发的专业人士,尤其是有一定编程基础的研究人员和技术工程师。 使用场景及目标:适用于需要理解和实施风电与储能联合调频项目的团队。主要目标是提高电网稳定性,减少风电波动带来的负面影响,同时延长储能系统的使用寿命。 其他说明:文中提供了大量实用的Python代码示例,涵盖了从数据生成到控制逻辑实现再到模型验证的全过程。对于希望深入理解风储调频系统的工作机制和技术挑战的人来说,是一份非常有价值的参考资料。

    HCIA-Storage V4.5 培训教材 合集

    HCIA-Storage V4.5 培训教材 合集

    基于S7-1200与博途V15的PLC小车自动往返控制系统设计与仿真

    内容概要:本文详细介绍了利用西门子S7-1200系列PLC和博途V15软件平台构建的小车自动往返控制系统。首先进行硬件组态,选择合适的CPU并配置输入输出点位,确保限位开关和急停按钮的有效接入。接着编写梯形图逻辑,实现小车在AB两点间的精确控制,采用定时器互锁机制避免电机损坏。然后设计触摸屏界面,通过WinCC创建动画效果展示小车运动状态,并设置按钮操作实现手动与自动模式切换。最后进行联合仿真实验,解决常见错误如变量地址配置不当等问题,确保系统稳定运行。 适合人群:工业自动化领域的工程师和技术人员,尤其是对PLC编程和HMI设计有一定基础的学习者。 使用场景及目标:适用于需要掌握PLC控制系统设计全流程的专业人士,帮助他们理解如何整合硬件组态、梯形图编程以及HMI开发,最终完成一个完整的自动化工程项目。 其他说明:文中提供了详细的调试经验和技巧,附带74分钟的操作录像资料,有助于读者更好地理解和实践相关知识点。

    公司员工关怀工作清单.xls

    公司员工关怀工作清单

    基于ANSYS/LS-DYNA的多孔延时起爆与重复起爆仿真技术详解

    内容概要:本文详细介绍了如何利用ANSYS/LS-DYNA进行多孔延时起爆和重复起爆的仿真。首先强调了起爆点的时间线控制和材料参数设置的重要性,如使用*INITIAL_DETONATION关键字设定起爆时间和坐标,以及配置JWL方程等材料属性。接着讨论了重复起爆的具体实现方式,包括使用*CONTROL_TERMINATION配合重启动功能,确保起爆点的正确复用。此外,文章还提供了调试技巧,如检查起爆同步性和优化时间步控制,以确保仿真的准确性。最后,分享了一些实际应用中的经验和常见错误,帮助用户更好地理解和掌握这一复杂的技术。 适合人群:从事爆炸力学研究和爆破工程设计的专业人士,尤其是有一定ANSYS/LS-DYNA使用经验的工程师。 使用场景及目标:适用于需要精确控制多个起爆点时间延迟和多次起爆的应用场合,如矿山开采、隧道挖掘等领域的爆破作业仿真。目标是提高爆破效率,减少对周围环境的影响。 其他说明:文中提到的许多技术细节对于初学者来说可能会有一定的难度,因此建议从简单的单孔起爆开始练习,逐步掌握复杂的多孔延时和重复起爆技术。同时,保持良好的注释习惯有助于追踪参数修改历史,便于后续调试和维护。

    Java面向对象的三大特性:封装、继承与多态

    内容概要:本文档详细介绍了Java面向对象编程的三大核心特性:封装、继承与多态。封装通过访问修饰符限制属性的访问权限,确保数据的安全性和完整性,如Student类中将name和age设为私有属性并通过公共方法进行访问控制。继承使得子类可以复用父类的属性和方法,减少代码冗余,如Dog类继承了Animal类的属性和方法并增加了特有的bark()方法。多态分为编译时多态(方法重载)和运行时多态(方法重写),它允许不同对象以相同接口执行不同的行为,如Shape类及其子类Circle和Rectangle通过重写getArea()方法实现了不同的面积计算逻辑,并在Main类中展示了多态的实际应用。 适合人群:具有Java编程基础的学习者或开发者,特别是对面向对象概念有初步了解但需要深入理解的人群。 使用场景及目标:①掌握Java中封装的实现机制,学会使用访问修饰符保护类成员;②理解继承的概念,能够创建父子类关系并利用继承特性提高代码复用性;③熟悉多态的应用场景,能够在实际项目中运用多态特性实现灵活的对象行为。 阅读建议:本资源侧重于理论讲解与简单示例演示,建议读者在学习过程中结合实际编程练习加深理解,同时注意对比不同特性的应用场景,以便更好地掌握面向对象编程的核心思想。

    基于51单片机protues仿真的番茄计时器(仿真图、源代码、AD原理图、流程图、视频)

    基于51单片机protues仿真的番茄计时器(仿真图、源代码、AD原理图、流程图、视频) 设计一个番茄计时器。使用番茄工作法(番茄工作法是一种时间管理方法),选择一个待完成的任务,将番茄时间设为45分钟,专注工作,中途不允许做任何与该任务无关的事,直到番茄时钟响起,然后进行短暂休息一下(5分钟),然后再开始下一个番茄。每4个番茄时段再多休息5分钟。 按键1:单击设置45分钟倒计时,双击设置5分钟休息倒计时。 按键2:单击音乐播放,双击暂停。按键3:复位按键。 所需硬件:3个按键,1个动态数码管,1个蜂鸣器。 仿真图、源代码、AD原理图、流程图、视频

Global site tag (gtag.js) - Google Analytics