oracle的class12驱动没有实现jdbc对clob或blob的存储, 解决办法

在使用原生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
分析缘由:java

  1. 异常是说T4CPreparedStatement这个类调用的是一个抽象的方法,意思是它自己没有对jdbc的setCharacterStream进行实现。
    1. 咱们框架用的数据库驱动用的是oracle.sql.class12, 存储大字段发生异常以后, 我去看了T4CPreparedStatement的源码, 他继承了OraclePreparedStatement, OraclePreparedStatement中有setCharacterStream, setClob, setBlob方法的实现, 可是与jdbc的setCharacterStream,setClob, setBlob方法的参数类型是不同的,能够去看一下源码就懂了, 意思就是, OraclePreparedStatement或者T4CPreparedStatement都没有实现jdbc的setCharacterStream,setClob, setBlob方法, 只是继承了抽象的方法, 所以咱们在调用时才会报前面的异常,
    2. 解决办法: 更换oracle驱动, 以后我把驱动换为了odjbc6, 一样去看了源码, 发现OraclePreparedStatement有对jdbc的PrepareStatement处理大字段方法的实现, 完美解决问题;
相关文章
相关标签/搜索