Python3.6连接Oracle数据库的方法详解
2018-10-15 17:35
阅读:412
本文实例讲述了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 <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 [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程序设计有所帮助。
评论
亲,登录后才可以留言!