在我们的应用程序中,我们有一个简单的POJO类,其中包含一个Clob属性。
在获取Clob实体的字符串表示时,我遇到了问题。
假设我已经在POJO对象中查询和缓存了结果,现在我正试图获得Clob的字符串值,如下所示。
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
我是不是遗漏了什么?
发布于 2014-03-12 18:53:25
Clob对象不是存储在数据库中的CLOB值的副本。它是一个定位器(指针),它在结果集关闭后变得无效。在处理结果集时,需要复制CLOB内容。
发布于 2014-03-31 11:12:04
可以通过将progressiveStreaming=2;参数添加到连接url来解决此问题。
完整指定的连接URL如下所示:
jdbc:db2://localhost:50000/SAMPLE:progressiveStreaming=2;如果对该参数有异常,则向其添加以下内容或添加这些参数的任何一个或组合来修复该参数:
jdbc:db2://localhost:50000/SAMPLE:driverType=4;fullyMaterializeLobData=true;fullyMaterializeInputStreams=true;progressiveStreaming=2;progresssiveLocators=2;它是首选使用db2jcc4.jar
发布于 2017-12-01 14:23:04
对于hibernate用户,当映射到数据库Lob类型(BLOB或CLOB)时,应该对字段进行注释@Lob,并且不需要保留副本,您可以像这样直接将其转换为字符数组。
(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;。
https://stackoverflow.com/questions/22360721
复制相似问题