【问题标题】:cannot convert clob to string无法将 clob 转换为字符串
【发布时间】:2011-01-17 17:14:37
【问题描述】:

我正在尝试将我的 clob 对象转换为字符串以在我的 JSTL 页面上显示它,因为我正在编写以下代码

public String convertClobToString(Clob clob){
     String toRet="";
     if(clob!=null)
     {
         try
         {
             long length=clob.length();
             toRet=clob.getSubString(1, (int)length);
         }
         catch(Exception ex)
         {
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
             ex.printStackTrace();
         }
     }
     return toRet;
 }

但是在使用“long length = clob.length()”计算长度时,它会抛出以下异常

java.sql.SQLException: Must be logged on to server

at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)
at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)
at oracle.jdbc.dbaccess.DBError.check_error(DBError.java:1160)
at oracle.jdbc.ttc7.TTC7Protocol.assertLoggedIn(TTC7Protocol.java:2196)
at oracle.jdbc.ttc7.TTC7Protocol.lobLength(TTC7Protocol.java:2698)
at oracle.sql.LobDBAccessImpl.length(LobDBAccessImpl.java:468)
at oracle.sql.CLOB.length(CLOB.java:214)
at org.hibernate.lob.SerializableClob.length(SerializableClob.java:33)
at com.starcj.cmt.application.dao.ApplicationDaoImpl.convertClobToString(ApplicationDaoImpl.java:110)
at com.starcj.cmt.termsandcondmgmt.dao.TermsAndCondDaoImpl.getAllActiveTermsandcond(TermsAndCondDaoImpl.java:91)
at com.starcj.cmt.termsandcondmgmt.service.TermsAndCondServiceImpl.getAllActiveTermsAndCond(TermsAndCondServiceImpl.java:43)
at com.starcj.cmt.termsandcondmgmt.controller.TermsAndCondListingCMTController.handleRequest(TermsAndCondListingCMTController.java:66)
at org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter.handle(SimpleControllerHandlerAdapter.java:48)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:875)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:807)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:571)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:501)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Unknown Source)

除了必须登录到服务器

但我正在从数据库中获取 clob 对象

【问题讨论】:

  • 遇到同样的问题。仍然不明白它是如何发生的。请告诉我你是怎么解决的?

标签: java oracle hibernate clob


【解决方案1】:

Clob resume = Hibernate.createClob ( "This is Clob");

【讨论】:

    【解决方案2】:

    在您的休眠实体(我们看不到)中,将属性声明为String 类型并使用@Lob 对其进行注释(同样,我不知道您使用的是注释还是XML),并且它无需任何手动转换即可工作。

    发生这种情况是因为在您尝试解析实体时,会话和底层连接已关闭,因此您无法从数据库中流式传输 CLOB 的值。

    上述解决方案的替代方案可能是使用OpenSessionInView 过滤器。它会让你在渲染视图(即你的 jsps)时打开会话(和底层数据库连接)

    【讨论】:

      【解决方案3】:

      您从哪里获得 CLOB?创建它的连接是否仍然打开? 该错误消息似乎表明数据库连接已在此期间关闭。 如果您使用的是 Hibernate,Hibernate Session 是否仍然打开?

      【讨论】:

      • 你能正确编辑你的堆栈跟踪和代码吗?这是通过在每行之前放置四个空格来完成的。
      • 我正在使用 oracle 9.0 并且正在使用休眠并且连接未关闭同时连接仍处于打开状态
      • “连接未关闭”。你能证实吗?也许像hibernateSession.createSQLQuery("select * from dual").executeUpdate()
      猜你喜欢
      • 1970-01-01
      • 2013-10-02
      • 2012-07-10
      • 2013-07-05
      • 2012-09-19
      • 2023-03-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多