溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python應(yīng)用cx_Oracle獲取oracle中的clob字段問題

發(fā)布時(shí)間:2021-02-03 11:14:49 來源:億速云 閱讀:354 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下Python應(yīng)用cx_Oracle獲取oracle中的clob字段問題,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

最近在用Python編寫連接數(shù)據(jù)庫獲取記錄的腳本,其中用到了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/yang@127.0.0.1:1523/yangdb')
對于dsn 方式:
makedsn(IP/HOST,PORT,TNSNAME)
dsn=cx_Oracle.makedsn('127.0.0.1','1523','yangdb')
db3=cx_Oracle.connect('yang','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','1523','yangdb')
db1=cx_Oracle.connect(username,pwd,dsn)
--獲取游標(biāo)
cursor = db1.cursor() 
--執(zhí)行查詢
sql = "select * from tab" 
cursor.execute(sql)
--獲取數(shù)據(jù) ,可以有多種方式 fetchall(),fetchmang(N)(N 為正整數(shù)),fetchone()
result = cursor.fetchall() 
count = cursor.rowcount

在自己進(jìn)行cursor.fetchall()操作后,得出result如下:

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

這其中有clob字段。搜尋了半天,有應(yīng)用dbms_lob.substr(clob字段,4000,1)這種方法容易報(bào)錯(cuò),并且和其他字段一起選擇時(shí),出現(xiàn)字符緩沖區(qū)不足的問題。

之后又找到方法說新建個(gè)字段然后利用這個(gè)dbms_lob的方法將clob字段轉(zhuǎn)換為一個(gè)新的temp字段。但是這個(gè)方法你無法確定選取多長的字符串。

最后通過詢問后才發(fā)現(xiàn)原來問題出現(xiàn)在我使用了cursor.fetchall()這個(gè)方法,只需要我在fetchall之前對cursor進(jìn)行操作,即:

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

問題解決!

看完了這篇文章,相信你對“Python應(yīng)用cx_Oracle獲取oracle中的clob字段問題”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI