国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python3.6連接Oracle數據庫的方法詳解

2020-01-04 15:03:10
字體:
來源:轉載
供稿:網友

本文實例講述了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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 延寿县| 札达县| 永仁县| 普兰店市| 子长县| 长阳| 青冈县| 交城县| 武胜县| 绥芬河市| 台山市| 潍坊市| 新乐市| 双辽市| 桂阳县| 思南县| 蒲江县| 武穴市| 新安县| 沂南县| 绥中县| 遂平县| 邯郸县| 吉木萨尔县| 齐齐哈尔市| 绿春县| 维西| 且末县| 岳阳县| 留坝县| 曲松县| 南郑县| 宣威市| 西乡县| 始兴县| 霞浦县| 汶川县| 页游| 长汀县| 马龙县| 钟山县|