1. 程式人生 > 資料庫 >Python如何應用cx_Oracle獲取oracle中的clob欄位問題

Python如何應用cx_Oracle獲取oracle中的clob欄位問題

最近在用Python編寫連線資料庫獲取記錄的指令碼,其中用到了cx_Oracle模組。它的語法主要如下:

cx_Oracle.connect('username','pwd','IP/HOSTNAME:PORT/TNSNAME')
import cx_Oracle
db1=cx_Oracle.connect('yang','yang','127.0.0.1:1523/yangdb')
db2=cx_Oracle.connect('yang/[email protected]:1523/yangdb')
對於dsn 方式:
makedsn(IP/HOST,PORT,TNSNAME)
dsn=cx_Oracle.makedsn('127.0.0.1','1523','yangdb')
db3=cx_Oracle.connect('yang',dsn)
例子:
oracle@rac3:/home/oracle/python>vim conndb4.py 
import cx_Oracle
username = "yang"
pwd = "yang"
--建立連線
dsn=cx_Oracle.makedsn('127.0.0.1','yangdb')
db1=cx_Oracle.connect(username,pwd,dsn)
--獲取遊標
cursor = db1.cursor() 
--執行查詢
sql = "select * from tab" 
cursor.execute(sql)
--獲取資料 ,可以有多種方式 fetchall(),fetchmang(N)(N 為正整數),fetchone()
result = cursor.fetchall() 
count = cursor.rowcount 

在自己進行cursor.fetchall()操作後,得出result如下:

('HAD_ZYBJ_420_0003','HAD_LINK_TEMPLATE','TYPE',1,'LINK_PID',None,'值域檢查','道路基本屬性檢查','Fatal','TYPE欄位存在非0、1、2的值',<cx_Oracle.LOB object at 0x00000000071E2170>)
('HAD_ZYBJ_420_0004','LANE_NUM','非空檢查','LANE_NUM欄位不能為空',<cx_Oracle.LOB object at 0x00000000071E2190>)
('HAD_ZYBJ_420_0005','SEQ_NUM','SEQ_NUM欄位不能為空',<cx_Oracle.LOB object at 0x00000000071E21B0>)
('HAD_ZYBJ_420_0006','WIDTH','WIDTH欄位不能為空',<cx_Oracle.LOB object at 0x00000000071E21D0>)
。。。

這其中有clob欄位。搜尋了半天,有應用dbms_lob.substr(clob欄位,4000,1)這種方法容易報錯,並且和其他欄位一起選擇時,出現字元緩衝區不足的問題。

之後又找到方法說新建個欄位然後利用這個dbms_lob的方法將clob欄位轉換為一個新的temp欄位。但是這個方法你無法確定選取多長的字串。

最後通過詢問後才發現原來問題出現在我使用了cursor.fetchall()這個方法,只需要我在fetchall之前對cursor進行操作,即:

cursor.execute(sql)
for row in cursor:
print(row[11])#或者print(row[11].read()),row[11]是clob欄位

問題解決!

以上這篇Python如何應用cx_Oracle獲取oracle中的clob欄位問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。