python连接oracle数据库_Python3.6连接Oracle数据库的方法详解

本文实例讲述了Python3.6连接Oracle数据库的方法。分享给大家供大家参考,具体如下:

下载cx_Oracle模块模块:

这里下载的是源码进行安装

[root@oracle oracle]# tar xf cx_Oracle-5.2.1.tar.gz

[root@oracle oracle]# cd cx_Oracle-5.2.1

[root@oracle cx_Oracle-5.2.1]# python setup.py build

Traceback (most recent call last):

File "setup.py", line 170, in

raise DistutilsSetupError("cannot locate an Oracle software " \

distutils.errors.DistutilsSetupError: cannot locate an Oracle software installation

报错解决办法:在root用户的.bash_profile文件中添加oracle_home的环境变量

export ORACLE_HOME=/u01/app/product/11.2.0/dbhome_1

PATH=${ORACLE_HOME}/bin:$PATH:$HOME/bin

[root@oracle cx_Oracle-5.2.1]# source /root/.bash_profile

[root@oracle cx_Oracle-5.2.1]# echo ${ORACLE_HOME}

/u01/app/product/11.2.0/dbhome_1

然后继续build:

[root@oracle cx_Oracle-5.2.1]# python setup.py build

running build

running build_ext

后面输出信息省略

[root@oracle cx_Oracle-5.2.1]# python setup.py install

running install

running bdist_egg

后面输出信息省略

按照完成之后,进行验证模块:

>>> import cx_Oracle

Traceback (most recent call last):

File "", line 1, in

ImportError: libclntsh.so.11.1: cannot open shared object file: No such file or directory

解决办法:在root用户的.bash_profile文件中添加LD_LIBRARY_PATH的环境变量

LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib:/usr/local/lib

export LD_LIBRARY_PATH

[root@oracle cx_Oracle-5.2.1]# source /root/.bash_profile

[root@oracle cx_Oracle-5.2.1]# python

Python 3.6.1 (default, Jul 13 2017, 14:31:18)

[GCC 4.4.7 20120313 (Red Hat 4.4.7-17)] on linux

Type "help", "copyright", "credits" or "license" for more information.

>>> import cx_Oracle

#!/usr/bin/python

#coding=utf8

# import module

import cx_Oracle as oracle

# connect oracle database

db = oracle.connect('scott/redhat@192.168.223.138:1521/oracle.test')

# create cursor

cursor = db.cursor()

# execute sql

cursor.execute('select sysdate from dual')

# fetch data

data = cursor.fetchone()

print('Database time:%s' % data)

# close cursor and oracle

cursor.close()

db.close()

[oracle@oracle scripts]$ python connectoracle.py

Database time:2017-08-04 10:20:39

#!/usr/bin/python

#coding=utf8

import cx_Oracle as oracle

def oraclesql(cursor):

fp = open(r'/home/oracle/scripts/tablespace.sql')

fp_sql = fp.read()

cursor.execute(fp_sql)

data = cursor.fetchall()

return data

if __name__ == '__main__':

ipaddr = "192.168.223.138"

username = "system"

password = "redhat"

oracle_port = "1521"

oracle_service = "oracle.test"

try:

db = oracle.connect(username+"/"+password+"@"+ipaddr+":"+oracle_port+"/"+oracle_service)

# 将异常捕捉,然后e就是抛异常的具体内容

except Exception as e:

print(e)

else:

cursor = db.cursor()

data = oraclesql(cursor)

for i in data:

print(i)

cursor.close()

db.close()

希望本文所述对大家Python程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值