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')
對(duì)于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之前對(duì)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字段問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python通配符之glob模塊的使用詳解
- Python全局變量global關(guān)鍵字詳解
- python里glob模塊知識(shí)點(diǎn)總結(jié)
- Python: glob匹配文件的操作
- Python全局變量與global關(guān)鍵字常見錯(cuò)誤解決方案
- 簡單了解python關(guān)鍵字global nonlocal區(qū)別
- 使用python matploblib庫繪制準(zhǔn)確率,損失率折線圖
- Python內(nèi)置函數(shù)locals和globals對(duì)比
- 淺析python標(biāo)準(zhǔn)庫中的glob
- Python3標(biāo)準(zhǔn)庫glob文件名模式匹配的問題
- Python中 Global和Nonlocal的用法詳解
- Python 內(nèi)置函數(shù)globals()和locals()對(duì)比詳解
- python中的global關(guān)鍵字的使用方法
- Python動(dòng)態(tài)參數(shù)/命名空間/函數(shù)嵌套/global和nonlocal
- Python文件名的匹配之clob庫
相關(guān)文章
Python在后臺(tái)自動(dòng)解壓各種壓縮文件的實(shí)現(xiàn)方法
這篇文章主要介紹了Python在后臺(tái)自動(dòng)解壓各種壓縮文件的實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
Django 允許局域網(wǎng)中的機(jī)器訪問你的主機(jī)操作
這篇文章主要介紹了Django 允許局域網(wǎng)中的機(jī)器訪問你的主機(jī)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-05-05
Python使用Matplotlib繪制散點(diǎn)趨勢(shì)線的代碼詳解
Matplotlib是一個(gè)用于數(shù)據(jù)可視化的強(qiáng)大Python庫,其基本功能之一是創(chuàng)建帶有趨勢(shì)線的散點(diǎn)圖,散點(diǎn)圖對(duì)于可視化變量之間的關(guān)系非常有用,本文將指導(dǎo)您使用Matplotlib繪制散點(diǎn)趨勢(shì)線的過程,涵蓋線性和多項(xiàng)式趨勢(shì)線,需要的朋友可以參考下2025-01-01
PHP實(shí)現(xiàn)發(fā)送和接收J(rèn)SON請(qǐng)求
本篇文章給大家分享了PHP實(shí)現(xiàn)發(fā)送和接收J(rèn)SON請(qǐng)求的詳細(xì)方法和實(shí)例代碼,有興趣的朋友可以參考學(xué)習(xí)下。2018-06-06
Python實(shí)現(xiàn)APP自動(dòng)化發(fā)微信群消息的示例代碼
本文主要介紹了Python實(shí)現(xiàn)APP自動(dòng)化發(fā)微信群消息的示例代,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下碼2022-01-01
基于python的opencv圖像處理實(shí)現(xiàn)對(duì)斑馬線的檢測(cè)示例
這篇文章主要介紹了基于python的opencv圖像處理實(shí)現(xiàn)對(duì)斑馬線的檢測(cè)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Python批量將csv文件編碼方式轉(zhuǎn)換為UTF-8的實(shí)戰(zhàn)記錄
近日在處理數(shù)據(jù)的時(shí)候發(fā)現(xiàn)有的文件為csv文件,Xiam 這篇文章主要給大家介紹了關(guān)于利用Python批量將csv文件編碼方式轉(zhuǎn)換為UTF-8的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
解決Django migrate No changes detected 不能創(chuàng)建表的問題
今天小編就為大家分享一篇解決Django migrate No changes detected 不能創(chuàng)建表的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05

