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

可以使用以下代码将 String 转换为 oracle.sql.CLOB: ```java import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; import java.io.IOException; import java.io.StringReader; import oracle.sql.CLOB; import oracle.jdbc.OraclePreparedStatement; import oracle.jdbc.pool.OracleDataSource; public class StringToClob { public static void main(String[] args) { String text = "Hello, world!"; // 要转换的字符串 try { OracleDataSource ds = new OracleDataSource(); // 创建 Oracle 数据源 ds.setURL("jdbc:oracle:thin:@//localhost:1521/orcl"); // 设置连接字符串 ds.setUser("username"); // 设置用户名 ds.setPassword("password"); // 设置密码 Connection conn = ds.getConnection(); // 获取数据库连接 // 创建 PreparedStatement 对象,用于执行 SQL 语句 PreparedStatement stmt = conn.prepareStatement("INSERT INTO my_table (my_clob) VALUES (?)"); CLOB clob = null; try { clob = CLOB.createTemporary(conn, false, CLOB.DURATION_SESSION); // 创建临时 CLOB clob.putString(1, text); // 设置 CLOB 内容 } catch (SQLException e) { e.printStackTrace(); } ((OraclePreparedStatement) stmt).setCLOB(1, clob); // 将 CLOB 对象设置为参数 stmt.executeUpdate(); // 执行 SQL 语句 clob.freeTemporary(); // 释放临时 CLOB stmt.close(); // 关闭 PreparedStatement 对象 conn.close(); // 关闭数据库连接 } catch (SQLException e) { e.printStackTrace(); } } } ``` 需要注意的是,上述代码中的 `my_table` 和 `my_clob` 分别表示数据库表名和 CLOB 类型的字段名,需要根据实际情况进行修改。另外,`OracleDataSource`、`OraclePreparedStatement` 和 `CLOB` 都属于 Oracle JDBC API 的一部分,需要引入相应的 Jar 包。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值