搜尋
首頁後端開發Python教學Python使用cx_Oracle模組操作Oracle資料庫詳解

Python使用cx_Oracle模組操作Oracle資料庫詳解

May 07, 2018 am 11:47 AM
oraclepython操作

這篇文章主要介紹了Python使用cx_Oracle模組操作Oracle資料庫,結a合實例形式較為詳細的分析了cx_Oracle模組的下載、安裝及針對Orcle資料庫的連接、執行SQL語句、預存程序等相關操作技巧,需要的朋友可以參考下

本文實例講述了Python使用cx_Oracle模組操作Oracle資料庫。分享給大家供大家參考,具體如下:

ORACLE_SID參數,這個參數是作業系統中用到的,它是描述我們要預設連接的資料庫實例,對於一個機器上有多個實例的情況下,要修改後才能透過conn / as sysdba連接,因為這裡用到了預設的實例名。

簡而言之,打個比方,你的名字叫小明,但是你有很多外號。你父母叫你小明,但是朋友都叫你的綽號。

這裡你的父母就是oracle實例,小明就是sid,service name就是你的外號。

sid用於實例區分各個資料庫,service name用於外部連結。它們可能是不同的,要注意你得到的是哪個名字,合理使用,否則遠端連接別的資料庫可能出錯。

前言

Python自帶的模組中有很多操縱檔案的。我們可以把文件的資料讀出來,經過處理也可以將資料寫入文件中。但對於資料的管理和分析來說,資料庫還是專業一些。如果Python能和資料庫結合在一起,那麼就能結合兩種的優勢,提高效率。

工作中使用的是Oracle資料庫,Python有一個模組cx_Oracle可以與Oracle連接。要使用cx_Oracle,就要先下載。

1. 下載cx_Oracle

Python一個官方網站PyPI,上面有豐富的模組。 cx_Oracle就可以在PyPI中下載。開啟PyPI的網址https://pypi.python.org/pypi,在裡面搜尋cx_Oracle,即可找到模組,其下載位址為http://cx-oracle.sourceforge.net/。當然也可以透過其它的途徑下載。

下載之後就可以使用了。

2. 使用流程

簡單的使用流程如下:

①.引用模組cx_Oracle
②.連接資料庫
③ .取得cursor
④.使用cursor進行各種動作
⑤.關閉cursor
⑥.關閉連線

下面是一個簡單的範例:

# cx_Oracle.connect("使用者名稱/  密碼@ Oracle伺服器IP  /  Oracle的SERVICE_NAME")

取得Oracle的SERVICE_NAME:

su - oracle #切換至oracle用戶

env | grep ORACLE #查詢ORACLE的環境變數

ORACLE_SID=benguo # benguo就是SERVICE_NAME

#
import cx_Oracle                     #引用模块cx_Oracle
conn=cx_Oracle.connect('load/123456@localhost/ora11g')  #连接数据库
c=conn.cursor()                      #获取cursor
x=c.execute('select sysdate from dual')          #使用cursor进行各种操作
x.fetchone()
c.close()                         #关闭cursor
conn.close()                       #关闭连接

範例:

#coding:utf-8
import cx_Oracle
def main():
  conn = cx_Oracle.connect("zebra/zebra@192.168.0.113/benguo")
  cur =conn.cursor()
  r= cur.execute("select * from userinfo")
  print
  print r.fetchone()
if __name__ == '__main__':
  main()

3. 幾個用法

Python對資料庫的操作主要有2個面向:一個是寫數據,一個是讀數據。這2個面向的實作可以透過SQL語句實現,也可以透過儲存過程實現。所以cx_Oracle的主要用法有:

①. 執行SQL語句

②. 呼叫預存程序和函式。

4. 執行SQL語句

執行SQL語句很簡單,從上面的範例可以看出。使用cursor.execute即可執行。使用fetchone或fetchall即可將執行結果讀出來。

下面一個例子是Insert語句,使用的變數綁定。

import cx_Oracle
conn=cx_Oracle.connect('load/123456@loaclhost/ora11g')
c=conn.cursor()
x=c.execute('insert into demo(v) values(:1)',['nice'])
conn.commit();
c.close()
conn.close()

變數綁定和Oracle的動態SQL一樣,都是冒號將佔位符,也就是程式碼中的:1,變數的複製就是傳入一個List,即程式碼中的['nice']。有多少個變量,list中就應該對應多少個值,數目要一致,否則會報錯。

執行之後,可以使用連接的一個方法connect.commit(),將交易提交。

5. 呼叫預存程序與方法

直接上程式碼:

--存储过程代码:
CREATE OR REPLACE PROCEDURE P_DEMO(V1 IN VARCHAR2, V2 OUT VARCHAR2) IS
BEGIN
  V2 := V1;
END;

#Python代码:
import cx_Oracle
conn=cx_Oracle.connect('load/123456@localhost/ora11g')
c=conn.cursor()
str1='nice'
str2='  '#需要有值,即len(str2)>=len(str1)
x=c.callproc('p_demo',[str1,str2])
print(str2)
c.close()
conn.close()

呼叫預存程序使用的是

cursor.callproc

方法。在上面的預存程序中,一個變數的值是OUT型的,在Python中,對OUT型的變數賦值,主要該變數的長度不能小於預存程序中的。

<pre class='brush:php;toolbar:false;'>--函数代码: CREATE OR REPLACE function F_DEMO(V1 VARCHAR2) RETURN VARCHAR2 IS BEGIN RETURN V1; END;</pre>

#Python代码:
import cx_Oracle
conn=cx_Oracle.connect(&#39;load/123456@localhost/ora11g&#39;)
c=conn.cursor()
str1=&#39;nice&#39;
str2=c.callfunc(&#39;f_demo&#39;,cx_Oracle.STRING,[str1])
print(str2)
c.close()
conn.close()
#呼叫函數使用的方法是

cursor.callfunc

。這與呼叫預存程序不同之處在於,它需要指定傳輸參數的類型。

結束

#########透過cx_Oracle,可以是Python與Oracle資料庫相互溝通,這樣兩者就可以長處互補。 ######例如,可以將Python當成一個資料收集的工具,可以從Web,從檔案中取得數據,然後將這些資料儲存到Oracle資料庫中,在Oracle資料庫上進行資料的進一步分析。 ######相關推薦:###

python使用openpyxl庫修改excel表格資料方法

Python使用email模組對郵件進行編碼和解碼

#

以上是Python使用cx_Oracle模組操作Oracle資料庫詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何使用numpy創建多維數組?如何使用numpy創建多維數組?Apr 29, 2025 am 12:27 AM

使用NumPy創建多維數組可以通過以下步驟實現:1)使用numpy.array()函數創建數組,例如np.array([[1,2,3],[4,5,6]])創建2D數組;2)使用np.zeros(),np.ones(),np.random.random()等函數創建特定值填充的數組;3)理解數組的shape和size屬性,確保子數組長度一致,避免錯誤;4)使用np.reshape()函數改變數組形狀;5)注意內存使用,確保代碼清晰高效。

說明Numpy陣列中'廣播”的概念。說明Numpy陣列中'廣播”的概念。Apr 29, 2025 am 12:23 AM

播放innumpyisamethodtoperformoperationsonArraySofDifferentsHapesbyAutapityallate AligningThem.itSimplifififiesCode,增強可讀性,和Boostsperformance.Shere'shore'showitworks:1)較小的ArraySaraySaraysAraySaraySaraySaraySarePaddedDedWiteWithOnestOmatchDimentions.2)

說明如何在列表,Array.Array和用於數據存儲的Numpy數組之間進行選擇。說明如何在列表,Array.Array和用於數據存儲的Numpy數組之間進行選擇。Apr 29, 2025 am 12:20 AM

forpythondataTastorage,choselistsforflexibilityWithMixedDatatypes,array.ArrayFormeMory-effficityHomogeneousnumericalData,andnumpyArraysForAdvancedNumericalComputing.listsareversareversareversareversArversatilebutlessEbutlesseftlesseftlesseftlessforefforefforefforefforefforefforefforefforefforlargenumerdataSets; arrayoffray.array.array.array.array.array.ersersamiddreddregro

舉一個場景的示例,其中使用Python列表比使用數組更合適。舉一個場景的示例,其中使用Python列表比使用數組更合適。Apr 29, 2025 am 12:17 AM

Pythonlistsarebetterthanarraysformanagingdiversedatatypes.1)Listscanholdelementsofdifferenttypes,2)theyaredynamic,allowingeasyadditionsandremovals,3)theyofferintuitiveoperationslikeslicing,but4)theyarelessmemory-efficientandslowerforlargedatasets.

您如何在Python數組中訪問元素?您如何在Python數組中訪問元素?Apr 29, 2025 am 12:11 AM

toAccesselementsInapyThonArray,useIndIndexing:my_array [2] accessEsthethEthErlement,returning.3.pythonosezero opitedEndexing.1)usepositiveandnegativeIndexing:my_list [0] fortefirstElment,fortefirstelement,my_list,my_list [-1] fornelast.2] forselast.2)

Python中有可能理解嗎?如果是,為什麼以及如果不是為什麼?Python中有可能理解嗎?如果是,為什麼以及如果不是為什麼?Apr 28, 2025 pm 04:34 PM

文章討論了由於語法歧義而導致的Python中元組理解的不可能。建議使用tuple()與發電機表達式使用tuple()有效地創建元組。 (159個字符)

Python中的模塊和包裝是什麼?Python中的模塊和包裝是什麼?Apr 28, 2025 pm 04:33 PM

本文解釋了Python中的模塊和包裝,它們的差異和用法。模塊是單個文件,而軟件包是帶有__init__.py文件的目錄,在層次上組織相關模塊。

Python中的Docstring是什麼?Python中的Docstring是什麼?Apr 28, 2025 pm 04:30 PM

文章討論了Python中的Docstrings,其用法和收益。主要問題:Docstrings對於代碼文檔和可訪問性的重要性。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器