阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Python 安装cx_Oracle模块

109次阅读
没有评论

共计 2798 个字符,预计需要花费 7 分钟才能阅读完成。

想访问远程 Oracle 数据库,本地又不想安装几百兆的 Oracle Client(也木有 root 权限),安装 python 的 cx_Oralce 模块需要依赖 Oracle Instant Client 代替完整的 Oracle Client。

Oracle Instant Client 下载:http://www.oracle.com/technetwork/topics/linuxx86-64soft-092277.html

下载:

  1. instantclient-basic-linux.x64-11.2.0.4.0.zip
  2. instantclient-sqlplus-linux.x64-11.2.0.4.0.zip
  3. instantclient-sdk-linux.x64-11.2.0.4.0.zip

解压文件放到如下目录:

$HOME/oracle/instantclient_11_2

拷贝 tnsnames.ora 文件,在 /home/oracle/instantclient_11_2 目录下创建 network/admin 目录,并将 tnsnames.ora 文件拷贝进去(这个貌似不是必要条件,出了问题的话就补上吧)

~/.bashrc 设置:

export ORACLE_HOME=$HOME/oracle/instantclient_11_2
export TNS_ADMIN=$ORACLE_HOME/network/admin
export DYLD_LIBRARY_PATH=$ORACLE_HOME
export PATH=$ORACLE_HOME:$PATH

下面就是该安装 cx_Oracle 的 python 模块了,下载直接 python setup.py install

由于非 root 的权限,会报无 /lib64/python2.6/site-packages/ 目录读写权限

可以改写 python 的安装目录

export PATH=$ORACLE_HOME:$PATH

然后 source .bashrc 生效

接下来可以安装了:python setup.py install –prefix=~/.local(牛逼闪闪啊,直接在原目录前加了个本地目录前缀,华丽丽的解决非 root 的壁垒)

顺其自然的又报错了(奔溃呀),/usr/bin/ld: cannot find -lclntsh

这个错误之前在 mac 上装 cx_Oracle 时候没遇到,百度解决方案,得知是没有找到 lib 下的 libclntsh.so 函数库

其实是有的,只不过名字改了,加软链接:

ln -s libclntsh.so.11.1 libclntsh.so

再次安装解决。

补充:

非 root 安装 rpm 包

首先把 RPM 包解压出来,然后放在自己的目录下,并且添加好环境变量
解压的命令为:
rpm2cpio ctags-5.8-2.el6.x86_64.rpm | cpio -idvm
这样就会按包里的目录结构解压到当前目录,如果是家目录的话,可以在家目录下的.bashrc 这样添加环境变量

  1. vim ~/.bashrc
  2. export PATH=$PATH:$HOME/usr/bin/

重新登录或者 source ~/.bashrc 文件,就可以使用这个程序了

easy_install –prefix=~/.local cx_Oracle

卸载:

python setup.py install --record record.txt --prefix=~/.local
然后删除 record.txt 里的所有文件

贴段 cx_Oracle 使用代码,作为备忘:

import cx_Oracle
class ConnectOracle:
    def __init__(self, username, passwd, locate):
        self.login = {}
        self.db = None
        self.cursor = None
        self.login[‘username’] = username
        self.login[‘passwd’] = passwd
        self.login[‘locate’] = locate

    def connect_oracle(self):
        try:
            self.db = cx_Oracle.connect(self.login[‘username’], self.login[‘passwd’], self.login[‘locate’])  # 登录内搜数据库
            self.db.autocommit = False  # 关闭自动提交
            self.cursor = self.db.cursor()  # 设置 cursor 光标
            return True
        except:
            print ‘can not connect oracle’
            return False

    def close_oracle(self):
        self.cursor.close()
        self.db.close()

    def select_oracle(self, sql, num=0, temp=None):
        if self.connect_oracle():
            if temp:
                self.cursor.executemany(sql, temp)
            else:
                self.cursor.execute(sql)
            if num:
                content = self.cursor.fetchmany(num)
            else:
                content = self.cursor.fetchall()
            self.close_oracle()
            return content
        return False

    def insert_oracle(self, sql, temp=None):
        try:
            self.connect_oracle()
            if temp:
                self.cursor.executemany(sql, temp)
                # 执行多条 sql 命令
            else:
                self.cursor.execute(sql)
        except:
            print “insert 异常 ”
            self.db.rollback()  # 回滚
        finally:
            self.db.commit()
            self.close_oracle()

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-04/130635.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计2798字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中