CS_Oracle是一款Python庫,它提供了與Oracle數據庫進行交互的接口,極大地方便了Python開發者進行數據庫開發。
例如,我們可以使用cs_oracle連接Oracle數據庫,查詢一個學生表格的所有數據:
import cs_Oracle
con = cs_Oracle.connect('usrname/pwd@ip:port/sid')
cur = con.cursor()
cur.execute('SELECT * FROM student')
data = cur.fetchall()
print(data)
cur.close()
con.close()
如上代碼所示,我們首先使用connect()函數連接數據庫。其中,我們需要指定數據庫的用戶名、密碼、IP地址、端口號以及sid。接下來,我們使用cursor()函數獲取數據庫的游標,在游標上調用execute()函數執行SQL語句,并通過fetchall()方法獲取數據。最后,我們關閉游標和數據庫連接。
我們可以使用cs_oracle進行數據的增、刪、查、改。例如,我們可以添加一個學生:
import cs_Oracle
con = cs_Oracle.connect('usrname/pwd@ip:port/sid')
cur = con.cursor()
cur.execute("INSERT INTO student (name, age) VALUES ('小明', 18)")
con.commit()
cur.close()
con.close()
如上代碼所示,我們執行了一條SQL語句,向學生表格中插入了一個名字為“小明”,年齡為18的學生。我們需要注意到,在插入、更新、刪除操作完成后,我們需要調用commit()函數提交事務,并關閉游標和數據庫連接。
除了基本的SQL操作外,cs_oracle還提供了批量插入、序列操作、LOB數據操作等高級特性。例如,我們可以批量插入10000條學生記錄:
import cs_Oracle
con = cs_Oracle.connect('usrname/pwd@ip:port/sid')
cur = con.cursor()
data = [('小明', 18), ('小紅', 19), ('小蘭', 20), ...]
cur.bindarraysize = len(data)
cur.setinputsizes(str, int)
cur.executemany('INSERT INTO student (name, age) VALUES (:1, :2)', data)
con.commit()
cur.close()
con.close()
如上代碼所示,我們將10000條學生信息存儲在一個列表中,并調用executemany()函數批量執行插入操作,而不是逐條執行。通過調整bindarraysize和setinputsizes、使用綁定變量,我們可以高效地執行插入操作。
總之,cs_oracle是一款極為方便的Python庫,它提供了各種高級特性,可以幫助Python開發者高效地進行系統開發。像這樣的Python庫還有很多,值得我們去細看和探索。