记一次Java读取DB2 CLOB数据遇到的问题

最初我的代码是这样的,

statement = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);statement.executeQuery(SQL语句);

然后调试的时候一直报错:DB2 SQL error: SQLCODE: -270, SQLSTATE: 42997, SQLERRMC: 53

sql语句在db2中直接执行是不会报错的

后来查看了对方数据库中的字段有两个是CLOB类型

在db2中直接执行是没有使用scrollable cursor游标的,解决方案就是createStatement的时候不传任何参数,修改后代码:

statement = conn.createStatement();statement.executeQuery(SQL语句);

这样是正常可以查到了,但是那两个CLOB返回的是两个对象,导致无法获取真正的内容,后来在sql中把这两个字段直接处理成String后就解决了,下面贴一下大概的SQL语句:

SELECT dbms_lob.substr(result) result ,dbms_lob.substr(finding) finding from 表名 where ......

大概是这样的,result和finding就是CLOB类型的字段,这样就可以读到DB2中CLOB的内容了;

还有一种方式是代码中以读流的方式获取:

Clob clob = rs.getClob("relust");//java.sql.Clob
String detailinfo = "";
if(clob != null){
    detailinfo = clob.getSubString((long)1,(int)clob.length());
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值