oracle9i clob欄位插入 報錯ORA-01461

來源:互聯網
上載者:User

程式運行了大半年了,突然收到使用者的發現的問題,資料有時候儲存不進去。

 

後台顯示是ORA-01461: 僅可以為插入 LONG 列的 LONG 值

 

多翻定位才發現是oracle9i,有一個clob欄位,當插入資料的長度在1000、2000內,就會拋出這樣的錯誤。其他的情況都正常。

 

 

對此網上的解決方案實在是五花八門,有換驅動的,換資料庫的,修改hibernate配置等等。我想升級資料庫肯定是ok的,但成本太高了,而修改hibernate配置,把原來映射string類型修改成clob類型,後面又牽涉到修改實體類,service層等多個類,風險也太高。

 

 

還是用這位仁兄的方法把:

思路:將儲存的字串補上空格,讓其超過2000的長度即可,但僅限與緊急解決問題。
1、首先在.java檔案中引入import org.apache.commons.lang.StringUtils;
2、在此.java檔案的相應的方法裡添加如下判斷:

// 處理ora-1461問題(clob長度在1000-2000之間會出錯)
if (xml.length() >= 1000 && xml.length() <= 2000) {
xml = StringUtils.rightPad(xml, 2008);
}

 

 

 

其他參考:

http://xuebin530.blog.163.com/blog/static/3772147200972731915975/

http://showtime520.iteye.com/blog/304932http://www.iteye.com/topic/565169

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.