oracle11g java导出excel报错oracle.sql.CLOB@xxxx问题

在项目中遇到,生产导出excel报错的问题 oracle.sql.CLOB@xxxx的错误,测试导出没问题,一样的代码。

原来oracle数据库从10g以后,使用wm_concat,函数返回值会自动转成clob类型 oracle.sql.CLOB@xxxxx.

如下图:


解决方法:

1.从数据库改为如下拼接方式,listagg(),返回字符串,但是需要oracle11g上才支持,并且不支持distinct, 拼接长度不能大于4000,函数返回varchar2,最大长度4000

select listagg(headname, ',') within group(order by rownum) as headName,
       listagg(headCode, ',') within group(order by rownum) as headCode
  from (select t.col_name as headName, t.col_code as headCode
          from el_tree t
         where tree_code = 'ztesoft_pubnet_planobj_lgf_qry'
           and is_display = 'true'
         order by display_index asc) w

2.修改代码,读取clob需要用流的方法读取,如下:

Clob clob=(CLOB)a.get("NAME");

Reader is=clob.getCharacterStream();

char [] c= new char[(int)clob.length()];

is.read(c);

data=new String(c);

is.close;

总结:由于使用wm_concat函数,在oracle10g之后,返回值变成clob类型,因此,接收值的时候,用clob接收,用流进行读写,这样接收到的值就OK了

        我的项目里是把wm_concat改成listagg来拼接sql.数据就正常了。代码方面流读写方式,我没有在该项目中进行验证。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值