溫馨提示×

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

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

如何解決Oracle NClob讀寫問(wèn)題

發(fā)布時(shí)間:2021-07-28 11:24:59 來(lái)源:億速云 閱讀:153 作者:小新 欄目:數(shù)據(jù)庫(kù)

這篇文章主要介紹如何解決Oracle NClob讀寫問(wèn)題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

最近一個(gè)新項(xiàng)目中,嘗試在 Oracle 數(shù)據(jù)庫(kù)中使用 NCLOB 來(lái)保存大的 xml 字符串。

在代碼自動(dòng)生成工具(通過(guò) JDBC 驅(qū)動(dòng)程序,讀數(shù)據(jù)庫(kù)表結(jié)構(gòu),自動(dòng)生成對(duì)應(yīng)的 java 代碼,包含增加、刪除、修改、分頁(yè)查詢、根據(jù)主鍵查找等前臺(tái) html/js、后臺(tái)代碼 java),將 NCLOB 字段映射到 String 類型。

運(yùn)行代碼,無(wú)報(bào)錯(cuò)。使用 SQuirreL SQL 客戶端查看數(shù)據(jù),覺(jué)察數(shù)據(jù)未保存成功。

網(wǎng)上搜一通,有提到用 SetBigStringTryClob  的數(shù)據(jù)庫(kù)連接額外屬性的。總覺(jué)得好傻。也有提到用 setStringForClob 方法的,也比較笨。

最后在 Oracle 官網(wǎng)上,找到一個(gè)更好的辦法:

升級(jí) Oracle JDBC 驅(qū)動(dòng)程序,直接用 java JDBC 標(biāo)準(zhǔn)的 setString 函數(shù),保存成功!

對(duì)應(yīng)網(wǎng)址:

http://docs.oracle.com/cd/E11882_01/java.112/e16548/oralob.htm#JJDBC28534

里面提到:

In Oracle Database 11g release 2 (11.2), the setBytes, setBinaryStream, setString, setCharacterStream, and setAsciiStream methods of PreparedStatement are extended to enhance the ability to work with BLOB, CLOB, and NCLOB target columns.

...

The SetBigStringTryClob connection property of Oracle Database 10g Release 1 (10.1) is no longer used or needed.

...

----------------------------

以上是“如何解決Oracle NClob讀寫問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

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

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

AI