• 简介

    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. 第二百六十一、二天 how can I坚持

    昨天在家宅了一天,晚上去看了个电影<寻龙诀>,感觉一般,虽然有黄渤.舒淇.十分打7分吧,画面倒是很震撼. 今天,去了趟东升八家郊野公园,想买个篮球玩玩来,可是超市里的太坑了,都是赠品还拿出 ...

  2. Base64编解码(C++版)

    #include <string> using namespace std; class ZBase64 { public:     /*编码     DataByte         [ ...

  3. UVA 315 315 - Network(求割点个数)

     Network  A Telephone Line Company (TLC) is establishing a new telephone cable network. They are con ...

  4. keil中编译时出现*** ERROR L107: ADDRESS SPACE OVERFLOW

    解决方法: http://zhidao.baidu.com/link?url=DWTVVdALVqPtUt0sWPURD6c1eEppyu9CXocLTeRZlZlhwHOA1P1xdesqmUQNw ...

  5. CodeForces 732B Cormen — The Best Friend Of a Man (贪心)

    题意:给定n和k表示,狗要在任意连续两天散步次数要至少为k,然后就是n个数,表示每天的时间,让你增加最少次数使得这个条件成立. 析:贪心,策略是从开始到最后暴力,每次和前面一个相比,如果相加不够k,那 ...

  6. spring mvc 详细执行流程

    名词解释 DispatcherServlet:整个spring MVC的前端控制器,由它来接管来自客户端的请求. HandlerMapping:DispatcherServlet会通过它来处理客户端请 ...

  7. Egret项目Typescript的编译报错

    今天编译项目,出现了一个奇怪的报错,如下: E:\engine\egret-core-3.1.2\tools\lib\typescript\tsclark.js:41531 1> if (fil ...

  8. Castle IOC容器实践之FactorySupport Facility

    PDF版本下载:http://file.ddvip.com/2008_10/1223538519_ddvip_4853.rar示例代码下载:http://file.ddvip.com/2008_10/ ...

  9. C++多态实现(虚函数,成员函数覆盖、隐藏)

    // 1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> using namespace ...

  10. [Selenium]中使用css选择器进行元素定位

    参考:http://www.cnblogs.com/webblog/archive/2009/07/07/1518274.html 常见语法 * 通用元素选择器,匹配任何元素 E 标签选择器,匹配所有 ...