首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >com.ibm.db2.jcc.am.SqlException:[jcc][10120][11936][4.14.88]无效操作: Lob已关闭。ERRORCODE=-4470,SQLSTATE=null

com.ibm.db2.jcc.am.SqlException:[jcc][10120][11936][4.14.88]无效操作: Lob已关闭。ERRORCODE=-4470,SQLSTATE=null
EN

Stack Overflow用户
提问于 2014-03-12 18:31:01
回答 3查看 5.4K关注 0票数 2

在我们的应用程序中,我们有一个简单的POJO类,其中包含一个Clob属性。

在获取Clob实体的字符串表示时,我遇到了问题。

假设我已经在POJO对象中查询和缓存了结果,现在我正试图获得Clob的字符串值,如下所示。

代码语言:javascript
复制
int aLength = (int)myPojo.getClobField().length();
String aStringValue = myPojo.getClobField().getSubString(1L, aLength);

但是上面的执行给了我错误,

com.ibm.db2.jcc.am.SqlException: jcc11936无效操作: Lob已关闭。ERRORCODE=-4470,SQLSTATE=null

我是不是遗漏了什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-03-12 18:53:25

Clob对象不是存储在数据库中的CLOB值的副本。它是一个定位器(指针),它在结果集关闭后变得无效。在处理结果集时,需要复制CLOB内容。

票数 1
EN

Stack Overflow用户

发布于 2014-03-31 11:12:04

可以通过将progressiveStreaming=2;参数添加到连接url来解决此问题。

完整指定的连接URL如下所示:

代码语言:javascript
复制
jdbc:db2://localhost:50000/SAMPLE:progressiveStreaming=2;

如果对该参数有异常,则向其添加以下内容或添加这些参数的任何一个或组合来修复该参数:

代码语言:javascript
复制
jdbc:db2://localhost:50000/SAMPLE:driverType=4;fullyMaterializeLobData=true;fullyMaterializeInputStreams=true;progressiveStreaming=2;progresssiveLocators=2;

它是首选使用db2jcc4.jar

票数 2
EN

Stack Overflow用户

发布于 2017-12-01 14:23:04

对于hibernate用户,当映射到数据库Lob类型(BLOB或CLOB)时,应该对字段进行注释@Lob,并且不需要保留副本,您可以像这样直接将其转换为字符数组。

代码语言:javascript
复制
(java.sql.Clob)payload.field1 bodyText = clobTest.getCharacterStream() 
 targetString = org.apache.commons.io.IOUtils.toString(bodyText) 
int length=targetString.length();
payload.PAYLOADHEADERS=targetString
return payload

确保在数据源配置属性中添加了progressiveStreaming=2;。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22360721

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档