Python3.6连接Oracle数据库的方法详解

 更新时间:2018年05月18日 08:48:19   作者:wadeson  
这篇文章主要介绍了Python3.6连接Oracle数据库的方法,较为详细的分析了cx_Oracle模块安装及Python3.6使用cx_Oracle模块操作Oracle数据库的具体操作步骤与相关注意事项,需要的朋友可以参考下

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

下载cx_Oracle模块模块:

https://pypi.python.org/pypi/cx_Oracle/5.2.1#downloads

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

[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 <module>
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 "<stdin>", line 1, in <module>
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相关内容感兴趣的读者可查看本站专题:《Python常见数据库操作技巧汇总》、《Python编码操作技巧总结》、《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总

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

相关文章

  • python标准库sys和OS的函数使用方法与实例详解

    python标准库sys和OS的函数使用方法与实例详解

    这篇文章主要介绍了python标准库sys和OS的函数使用方法与实例详解,需要的朋友可以参考下
    2020-02-02
  • yolov5返回坐标的方法实例

    yolov5返回坐标的方法实例

    这篇文章主要给大家介绍了关于yolov5返回坐标的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03
  • python的迭代器,生成器和装饰器你了解吗

    python的迭代器,生成器和装饰器你了解吗

    这篇文章主要为大家详细介绍了python的迭代器,生成器和装饰器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • Pyspark获取并处理RDD数据代码实例

    Pyspark获取并处理RDD数据代码实例

    这篇文章主要介绍了Pyspark获取并处理RDD数据代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Python自动生成代码 使用tkinter图形化操作并生成代码框架

    Python自动生成代码 使用tkinter图形化操作并生成代码框架

    这篇文章主要为大家详细介绍了Python自动生成代码,使用tkinter图形化操作并生成代码框架,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • 使用Python进行时间序列分析的8种绘图类型

    使用Python进行时间序列分析的8种绘图类型

    时间序列数据是按时间顺序按固定时间间隔排列的观测值的集合,每个观察对应于一个特定的时间点,并且可以以各种频率(例如,每天、每月、每年)记录数据,本文介绍了几种类型的绘图,可帮助您使用 Python 进行时间序列分析,并提供使用可免费访问的数据集的详细示例
    2023-09-09
  • PyQt5实现让QScrollArea支持鼠标拖动的操作方法

    PyQt5实现让QScrollArea支持鼠标拖动的操作方法

    今天小编就为大家分享一篇PyQt5实现让QScrollArea支持鼠标拖动的操作方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • 对于Python编程中一些重用与缩减的建议

    对于Python编程中一些重用与缩减的建议

    这篇文章主要介绍了对于Python编程中一些重用与缩减的建议,来自于IBM官方技术文档,需要的朋友可以参考下
    2015-04-04
  • 对Django中内置的User模型实例详解

    对Django中内置的User模型实例详解

    今天小编就为大家分享一篇对Django中内置的User模型实例详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08
  • matplotlib绘制直方图的基本配置(万能模板案例)

    matplotlib绘制直方图的基本配置(万能模板案例)

    本文主要介绍了matplotlib绘制直方图的基本配置(万能模板案例),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04

最新评论