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

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

概述在使用原生jdbc做保存大字段clob或者是blob时, 发生异常: ERROR [pool-12-thread-1] PartitionConsumerThread.run(128) | java.lang.AbstractMethodError: Method oraclebc/driver/T4CPreparedStatement.setCharacterStream(ILjava/io/R 在使用原生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,setBlob方法的参数类型是不一样的,可以去看一下源码就懂了, 意思就是, OraclePreparedStatement或者T4CPreparedStatement都没有实现jdbc的setCharacterStream,setBlob方法, 只是继承了抽象的方法, 因此我们在调用时才会报前面的异常,解决办法: 更换oracle驱动, 之后我把驱动换为了odjbc6,同样去看了源码, 发现OraclePreparedStatement有对jdbc的PrepareStatement处理大字段方法的实现, 完美解决问题;

总结

以上是内存溢出为你收集整理的oracle的class12驱动没有实现jdbc对clob或blob的存储, 解决办法全部内容,希望文章能够帮你解决oracle的class12驱动没有实现jdbc对clob或blob的存储, 解决办法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1166423.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存