1. 程式人生 > >oracle的class12驅動沒有實現jdbc對clob或blob的存儲, 解決辦法

oracle的class12驅動沒有實現jdbc對clob或blob的存儲, 解決辦法

statement 沒有 數據庫驅動 jdb sum stream char har tchar

在使用原生jdbc做保存大字段clob或者是blob時, 發生異常:
ERROR [pool-12-thread-1] PartitionConsumerThread.run(128) | java.lang.AbstractMethodError: Method oraclebc/driver/T4CPreparedStatement.setCharacterStream(ILjava/io/Reader;J)V is abstract
分析原因:

異常是說T4CPreparedStatement這個類調用的是一個抽象的方法,意思是它本身沒有對jdbc的setCharacterStream進行實現。
我們框架用的數據庫驅動用的是oracle.sql.class12, 存儲大字段發生異常之後, 我去看了T4CPreparedStatement的源碼, 他繼承了OraclePreparedStatement, OraclePreparedStatement中有setCharacterStream, setClob, setBlob方法的實現, 但是與jdbc的setCharacterStream,setClob, setBlob方法的參數類型是不一樣的,可以去看一下源碼就懂了, 意思就是, OraclePreparedStatement或者T4CPreparedStatement都沒有實現jdbc的setCharacterStream,setClob, setBlob方法, 只是繼承了抽象的方法, 因此我們在調用時才會報前面的異常,

解決辦法: 更換oracle驅動, 之後我把驅動換為了odjbc6, 同樣去看了源碼, 發現OraclePreparedStatement有對jdbc的PrepareStatement處理大字段方法的實現, 完美解決問題;

oracle的class12驅動沒有實現jdbc對clob或blob的存儲, 解決辦法