一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python3.6連接Oracle數據庫的方法詳解

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

2021-02-22 00:02wadeson Python

這篇文章主要介紹了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

這里下載的是源碼進行安裝

?
1
2
3
4
5
6
7
[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的環境變量

?
1
2
3
4
5
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:

?
1
2
3
[root@oracle cx_Oracle-5.2.1]# python setup.py build
running build
running build_ext

后面輸出信息省略

?
1
2
3
[root@oracle cx_Oracle-5.2.1]# python setup.py install
running install
running bdist_egg

后面輸出信息省略

按照完成之后,進行驗證模塊:

?
1
2
3
4
>>> 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的環境變量

?
1
2
LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib:/usr/local/lib
export LD_LIBRARY_PATH
?
1
2
[root@oracle cx_Oracle-5.2.1]# source /root/.bash_profile
[root@oracle cx_Oracle-5.2.1]# python
?
1
2
3
4
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
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#!/usr/bin/python
#coding=utf8
# import module
import cx_Oracle as oracle
# connect oracle database
db = oracle.connect('scott/[email protected]: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()
?
1
2
[oracle@oracle scripts]$ python connectoracle.py
Database time:2017-08-04 10:20:39
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#!/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程序設計有所幫助。

原文鏈接:https://www.cnblogs.com/jsonhc/p/7283620.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色亚洲色图 | 亚洲干综合 | 婷婷色在线 | 91传媒制片厂制作传媒破解版 | 亚洲成色| 国产成人www免费人成看片 | 91短视频在线免费观看 | 撕开老师的丝袜白丝扒开粉嫩的小 | 嫩草视频在线观看视频播放 | 高清视频在线观看+免费 | 免费369看片入口 | 亚洲国产精品无码中文字满 | 免费高清www动漫视频播放器 | 肉文np高h | 亚洲色欲色欲综合网站 | 无码射肉在线播放视频 | 福利久草 | 男男互操文 | 亚欧视频在线观看 | 韩国三级年轻的小婊孑 | 波多野结衣一区免费作品 | 婷婷去我也去 | adult video在线观看 | 3黑人巨大vs北岛玲 3d肉浦团在线观看 3d动漫免费 | 久久久这里有精品999 | 国产亚洲精品一区二区在线播放 | 修修视频在线观看 | 国产午夜免费不卡精品理论片 | 深夜影院深a| 关晓彤被调教出奶水的视频 | 亚洲+欧美+国产+综合 | 我的年轻漂亮继坶三级 | 国产成人无精品久久久久国语 | 办公室强行丝袜秘书啪啪 | 亚洲 日本 天堂 国产 在线 | 狠狠干在线观看 | 无遮18禁在线永久免费观看挡 | 国产1区2区在线观看 | a毛片免费全部在线播放毛 a级在线看 | 国模娜娜一区二区三区 | 我的奶头被客人吸的又肿又红 |