小編給大家分享一下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/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) --獲取游標 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, '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字段。搜尋了半天,有應用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字段問題”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。