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

来源:互联网 发布:宜居星球知乎 编辑:程序博客网 时间:2024/05/19 01:10

在项目中遇到,生产导出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.数据就正常了。代码方面流读写方式,我没有在该项目中进行验证。

阅读全文
0 0
原创粉丝点击