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

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

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

如下图:

go

ZmlsZTovLy9EOlznrKzkuInmlrnlm77lvaLnlYzpnaLnrqHnkIZcMzE2OTQ5ODAzXDMxNjk0OTgwM1xJbWFnZVxHcm91cFxYMjVfYEdEUkxKTkQ4fTVQYEZbTDJUNC5wbmc=

go

bad4371bd5849a2a640d3ccf5d33906c.png

解决方法:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值