Python3.6连接Oracle数据库的方法详解
Python / 管理员 发布于 7年前 193
本文实例讲述了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 buildTraceback (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_1PATH=${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 buildrunning buildrunning build_ext
后面输出信息省略
[root@oracle cx_Oracle-5.2.1]# python setup.py installrunning installrunning bdist_egg
后面输出信息省略
按照完成之后,进行验证模块:
>>> import cx_OracleTraceback (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/libexport 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 linuxType "help", "copyright", "credits" or "license" for more information.>>> import cx_Oracle
#!/usr/bin/python#coding=utf8# import moduleimport cx_Oracle as oracle# connect oracle databasedb = oracle.connect('scott/redhat@192.168.223.138:1521/oracle.test')# create cursorcursor = db.cursor()# execute sqlcursor.execute('select sysdate from dual')# fetch datadata = cursor.fetchone()print('Database time:%s' % data)# close cursor and oraclecursor.close()db.close()
[oracle@oracle scripts]$ python connectoracle.pyDatabase time:2017-08-04 10:20:39
#!/usr/bin/python#coding=utf8import cx_Oracle as oracledef oraclesql(cursor): fp = open(r'/home/oracle/scripts/tablespace.sql') fp_sql = fp.read() cursor.execute(fp_sql) data = cursor.fetchall() return dataif __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程序设计有所帮助。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号