本文實(shí)例講述了python連接oracle數(shù)據(jù)庫的方法,分享給大家供大家參考。具體步驟如下:
一、首先下載驅(qū)動(dòng):(cx_Oracle)
http://www.python.net/crew/atuining/cx_Oracle/
不過要注意一下版本,根據(jù)你的情況加以選擇。
二、安裝:
首先配置oracle_home環(huán)境變量
執(zhí)行那個(gè)exe安裝程序就可以了,它會(huì)copy一個(gè)cx_Oracle.pyd到Libsite-packages目錄下。
如果是linux,執(zhí)行
代碼如下:python setup.py build
python setup.py install
三、執(zhí)行一段測(cè)試程序:
代碼如下:import cx_Oracle
con = cx_Oracle.connect( "xjtu_test", "37343734","xjtu.world")
cursor = con.cursor()
cursor.close()
con.close()
里邊connect中的3個(gè)參數(shù)從左到右分別是:user, pass, TNS。
那個(gè)TNS可以用Oracle客戶端工具中的Net Configuration Assistant來配置。
四、具體的cx_Oracle API可以參考:
http://www.python.net/crew/atuining/cx_Oracle/html/cx_Oracle.html
五、示例:
代碼如下:>>> import cx_Oracle
>>> conn=cx_Oracle.connect ('scott/tiger@oratest')
>>> curs=conn.cursor ()
>>> sql='select * from emp'
>>> rr=curs.execute (sql)
>>> row=curs.fetchone()
>>> row
(7369, 'SMITH', 'CLERK', 7902, datetime.datetime(1980, 12, 17, 0, 0), 800.0, None, 20)
>>> while row:
(ID,NAME)=(row[0],row[1])
row=curs.fetchone ()
print ID,NAME
7369 SMITH
7499 ALLEN
7521 WARD
7566 JONES
7654 MARTIN
7698 BLAKE
7782 CLARK
7788 SCOTT
7839 KING
7844 TURNER
7876 ADAMS
7900 JAMES
7902 日常
7934 MILLER
如果使用windows平臺(tái),執(zhí)行那段測(cè)試代碼時(shí)你肯定遇到問題了,一般會(huì)有以下問題:
① import cx_Oracle 時(shí)報(bào)告找不到OCI.DLL:
到裝了Oracle的機(jī)器上找一個(gè),然后copy到Libsite-packages目錄下就可以了。
② cx_Oracle.connect 時(shí)報(bào)告RuntimeError: Unable to acquire Oracle environment handle:
這個(gè)比較麻煩,按以下步驟來解決:(可能不需要所有的步驟,我沒有確認(rèn),不過把以下步驟都執(zhí)行了,確實(shí)問題就解決了)
首先,確認(rèn)你是在控制臺(tái)下邊來執(zhí)行這個(gè)python腳本的。而不是某些ide,例如:PyDev(它們似乎無法載入os的環(huán)境變量)。
其實(shí),在本機(jī)安裝Oracle(只安客戶端工具就可以了)。
最后,添加以下環(huán)境變量:(我給出我的,換成你自己的路徑就可以了)
代碼如下:ORACLE_HOME=D:OracleOra81
PATH=D:OracleOra81bin;
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選