您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關oracle插入clob字段出現問題怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
1.用insert語句,插入clob字段,如果插入內容超過4000,會提示字符串過長,處理的方法是,先聲明插入的字段為clob類型,如下:
insertSql = "DECLARE email_text clob := '%s'; begin insert into emails values ('%r','%s',email_text,'重點股票跟蹤(%s)','0',''); end;" % (
email_text,id, contactEamilAddress, dateInput)
更新以上方法會報出如下錯誤:
cx_Oracle.DatabaseError: ORA-06550: 第 1 行, 第 28 列:
PLS-00172: string literal too long
改成如下方法即可,把參數統一放在一個數組里:
insertSql = "insert into business_EMAILS values (:1,:2,:3,:4,'0','','1','1',:5)"
params = [id, contactEamilAddress, email_text,'重點股票跟蹤({0})'.format(dateInput),contactUserId]
cur.execute(insertSql,params)
conn.commit()
2.用python的結果集,讀取到clob字段的時候,轉化為str類型處理,如下:
cur_bbc.execute("select t.*, t.rowid from emails t where t.email_status = '0'")
res = cur_bbc.fetchall()
for record in res:
id = record[0]
to_email = record[1]
to_email_list = to_email.split(",")
email_text = record[2].read() --clob類型
關于“oracle插入clob字段出現問題怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。