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
分析原因:

创新互联建站专注于企业全网整合营销推广、网站重做改版、叙永网站定制设计、自适应品牌网站建设、H5开发商城建设、集团公司官网建设、外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为叙永等各大城市提供网站开发制作服务。

  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处理大字段方法的实现, 完美解决问题;

当前名称:oracle的class12驱动没有实现jdbc对clob或blob的存储,解决办法
网站URL:http://bzwzjz.com/article/pipici.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 移动网站建设 成都网站建设 成都网站建设 泸州网站建设 企业网站设计 成都网站建设 app网站建设 响应式网站设计 高端网站设计 攀枝花网站设计 成都网站设计 成都网站建设 网站制作 营销型网站建设 重庆网站建设 成都企业网站制作 专业网站设计 四川成都网站建设 成都网站设计 手机网站制作 成都网站设计 成都网站制作