• 简介

    cx_Oracle是用python连接oracle的驱动模块,参考文章:
    [cx_Oracle文档](http://cx-oracle.sourceforge.net/html/index.html)
    [木匣子](http://www.cnblogs.com/hzhida/archive/2012/08/13/2636735.html)
  1. 下载安装包
    cx_Oracle-5.1.2-10g-py26-1.x86_64.rpm
    oracle-instantclient12.1-basic-12.1.0.1.0-1.x86_64.rpm
    oracle-instantclient12.1-devel-12.1.0.1.0-1.x86_64.rpm

    官网下载地址:

    http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html
    http://cx-oracle.sourceforge.net/
  2. 安装
    安装命令:
    rpm -Uvh cx_Oracle-5.1.2-10g-py26-1.x86_64.rpm
    rpm -Uvh oracle-instantclient12.1-basic-12.1.0.1.0-1.x86_64.rpm
    rpm -Uvh oracle-instantclient12.1-devel-12.1.0.1.0-1.x86_64.rpm
  3. 配置环境变量
    vi /etc/profile在/etc/profile文件追加如下信息:
    export ORACLE_HOME=/usr/lib/oracle/12.1/client64
    export PATH=$PATH:$ORACLE_HOME/bin
    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
    export TNS_ADMIN=$ORACLE_HOME/network/admin

    执行:

    source /etc/profile
  4. 验证安装是否成功

    验证方法:在目标服务器上执行:
    python,import cx_Oracle

    如果验证失败,参考5异常处理

  5. 异常处理
    如果出现下面的错误:

    [root@client oracle]# python
    import cx_Oracle
    Traceback (most recent call last):
    File "<stdin>", line 1, in <module>
    ImportError: libclntsh.so.11.1: cannot open shared object file: No such file or directory
    ImportError: libclntsh.so.11.1: cannot open shared object file: No such file or directory
    这是由于驱动文件名称不对引起的
    在服务器上执行命令:
    find / -name libclntsh.so.*
    [root@client oracle]# find / -name libclntsh.so.*
    /usr/lib/oracle/12.1/client64/lib/libclntsh.so.12.1
    可见是文件名称不对,执行如下命令:
    cp /usr/lib/oracle/12.1/client64/lib/libclntsh.so.12.1
    /usr/lib/oracle/12.1/client64/lib/libclntsh.so.11.1
    重新执行第四步,验证安装是否成功
  • cx_Oracle增删改查

     import cx_Oracle
  • 连接

    dsn=cx_Oracle.makedsn(host, int(port), dbname)
    self.conn = cx_Oracle.connect(user, passwd ,dsn)
    self.cursor = self.conn.cursor()
  • def insert(self, sql, param, flag = True):
    sql = self.sqltran(sql, param)
    self.cursor.execute(sql)
    self.conn.commit()
  • def selectall(self, sql, param=None):
    sql = self.sqltran(sql, param)
    self.cursor.execute(sql)
    result = self.cursor.fetchall()
    return result
  • 更新
    def update(self, sql, param=None, flag = True):
    sql = self.sqltran(sql, param)
    self.cursor.execute(sql)
    self.conn.commit()
  • def delete(self, sql, param=None):
    sql = self.sqltran(sql, param)
    self.cursor.execute(sql)
    self.conn.commit()
  • 关闭连接
    def __del__( self ):
    if self.conn :
    self.conn.close()
  • sql转换
    def sqltran(self,sql,param):
    for i in range(0,len(param)):
    sql = sql.replace('%s',str(param[i]),1)
    return sql
  • 测试方法
    if __name__ == '__main__':
    param = ('id','name','addr',1)
    sql1= 'select id ,name, addr from test'
    sql0= 'select %s,%s,%s from test'
    sql2= 'insert into test (%s,%s,%s)values(4,4,4)'
    sql3= 'update test set name=222 where id=%s'
    sql4= 'delete from test where id=%s'
    print oracle.selectall(sql0,param)
    print oracle.insert(sql2, param)
    print oracle.selectOne(sql0,param)
    print oracle.update(sql3,('3'))
    print oracle.delete(sql4,('4'))
    print oracle.selectall(sql0,param)
    print 'success'

cx_Oracle安装说明的更多相关文章

  1. Python cx_Oracle 安装小记

    因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.请访问我的个人网站获取这篇文章的最新内容,Python cx_Oracle 安装小记 SQLAlchemy 是 Pytho ...

  2. cx_oracle 安装和配置

    前提条件: 已经成功安装python 已经成功安装oracle客户端 1.去官网上下载对应版本的cx_oracle http://cx-oracle.sourceforge.net/ 注意版本必须与p ...

  3. ArcGIS ArcMap 问题(ArcMap闪退、cx_oracle安装不上)

    一.问题描述 1.ArcMap闪退 2.安装32位cx_oracle提示python目录不存在 二.解决方案 1.修改pythoncore的文件目录,指向C:\Python27\ArcGIS10.3\ ...

  4. python3.6的安装及cx_oracle安装

    一.创建所需目录mkdir -p /home/用户名/software/python3.6.1mkdir -p /home/用户名/priv/bydmkdir -p /home/用户名/priv/by ...

  5. Cx_Oracle 安装

    1. 下载安装 2.把oci.ddl  oraociei11.dll 放到C:\Python33\Lib\site-packages路径下

  6. 使用pip安装 cx_Oracle 模块

    1. 系统环境,linux, python3.5, pip以下命令的执行均使用root用户. 2. 执行 pip install cx_Oracle出错,提示不能定位Oracle的安装.出现该问题的原 ...

  7. Windows 环境下于虚拟环境安装源码安装 cx_oracle

    安装前提条件: (1).安装 instantclient-basic-nt (2).安装 instantclient-sdk-nt (3).安装 Microsoft Visual C++ Compil ...

  8. 安装cx_Oracle 6

    首先声明,本文是在Linux 环境下进行安装.不涉及Windows 版安装. 一. 了解cx_Oracle 安装要求 要python 通过cx_Oracle 6 操作Oracle 数据库,以下几个条件 ...

  9. Windows 环境下于虚拟环境中源码安装 cx_oracle

    安装前提条件: (1).安装 instantclient-basic-nt (2).安装 instantclient-sdk-nt (3).安装 Microsoft Visual C++ Compil ...

随机推荐

  1. windows下编译支持https的libcurl

    本文参考http://blog.csdn.net/fragmentalice/article/details/39430293特此感谢.公司项目中用到几个http get请求,用的libcurl开源库 ...

  2. Spark生态之Spark MLbase/MLlib

  3. 终于弄好了 homework-09

    近一周的时间,顶着编译大作业严重搁置的压力,天天搞,终于把网页动态展示的搞出来了!恩,还挺好看~ 因为是最后一次作业了,也是因为天生的完美主义强迫症,做到自己满意才放心停下来.不过,这个过程,看着同学 ...

  4. CentOS查看系统信息-CentOS查看命令

    一:查看cpu more /proc/cpuinfo | grep "model name" grep "model name" /proc/cpuinfo 如 ...

  5. Codeforces Round #349 (Div. 2) D. World Tour (最短路)

    题目链接:http://codeforces.com/contest/667/problem/D 给你一个有向图,dis[i][j]表示i到j的最短路,让你求dis[u][i] + dis[i][j] ...

  6. HDU1028Ignatius and the Princess III(母函数)

    http://acm.hdu.edu.cn/showproblem.php?pid=1028 母函数: 例1:若有1克.2克.3克.4克的砝码各一 枚,能称出哪几种重量?各有几种可能方案? 如何解决这 ...

  7. Excel Xll开发资料

    下载地址:http://bbs.jjxj.org/forum.php?mod=viewthread&tid=37943&extra=page%3D1&page=1& 财 ...

  8. Spring MVC Framework 注解

    ControllerAdvice Spring MVC Framework会把 @ControllerAdvice注解内部使用 @ExceptionHandler.@InitBinder.@Model ...

  9. python dict{}和set([])

    200 ? "200px" : this.width)!important;} --> 介绍 dict(dictionary),在其他语言中也称为map,使用键-值(key- ...

  10. jQuery 源码解析一:jQuery 类库整体架构设计解析

    如果是做 web 的话,相信都要对 Dom 进行增删查改,那大家都或多或少接触到过 jQuery 类库,其最大特色就是强大的选择器,让开发者脱离原生 JS 一大堆 getElementById.get ...