Python 安装并使用cx_Oracle模块

cx_Oracle支持Python访问Oracle数据库。 它符合Python Database API v2.0规范 ,包含大量添加内容和一些排除项。

Python程序调用cx_Oracle函数。 在内部,cx_Oracle动态加载Oracle客户端库以访问Oracle数据库。

下载:

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_HOMEexport 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()

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/221615.html<

(0)
运维的头像运维
上一篇2025-04-15 02:58
下一篇 2025-04-15 03:00

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注