Failed to lazily initialize a collection

4 respostas
Dassayev

Boa tarde pessoal!

Estou com um problema com o Hibernate + JSF. Tenho um objeto "OrdemServico" e nesse objeto tenho uma lista de "ProcessoOs". Quando vou exibir essa lista na minha página JSF um erro é gerado.

SEVERE: Servlet.service() for servlet Faces Servlet threw exception
org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: br.com.jdsistemas.audcont.to.OrdemServico.processoOsList, no session or session was closed
        at org.hibernate.collection.AbstractPersistentCollection.throwLazyInitializationException(AbstractPersistentCollection.java:380)
        at org.hibernate.collection.AbstractPersistentCollection.throwLazyInitializationExceptionIfNotConnected(AbstractPersistentCollection.java:372)
        at org.hibernate.collection.AbstractPersistentCollection.readSize(AbstractPersistentCollection.java:119)
        at org.hibernate.collection.PersistentBag.isEmpty(PersistentBag.java:255)
        at org.apache.el.parser.AstEmpty.getValue(AstEmpty.java:53)
        at org.apache.el.parser.AstNot.getValue(AstNot.java:42)
        at org.apache.el.parser.AstAnd.getValue(AstAnd.java:42)
        at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:186)
        at com.sun.facelets.el.TagValueExpression.getValue(TagValueExpression.java:71)
        at javax.faces.component.UIComponentBase.isRendered(UIComponentBase.java:370)
        at org.ajax4jsf.renderkit.RendererBase.renderChild(RendererBase.java:276)
        at org.ajax4jsf.renderkit.RendererBase.renderChildren(RendererBase.java:262)
        at org.richfaces.renderkit.html.PanelRenderer.doEncodeChildren(PanelRenderer.java:220)
        at org.richfaces.renderkit.html.PanelRenderer.doEncodeChildren(PanelRenderer.java:215)
        at org.ajax4jsf.renderkit.RendererBase.encodeChildren(RendererBase.java:121)
        at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:812)
        at javax.faces.component.UIComponent.encodeAll(UIComponent.java:886)
        at javax.faces.render.Renderer.encodeChildren(Renderer.java:137)
        at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:812)
        at javax.faces.component.UIComponent.encodeAll(UIComponent.java:886)
        at javax.faces.component.UIComponent.encodeAll(UIComponent.java:892)
        at com.sun.facelets.FaceletViewHandler.renderView(FaceletViewHandler.java:592)
        at org.ajax4jsf.application.ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:100)
        at org.ajax4jsf.application.AjaxViewHandler.renderView(AjaxViewHandler.java:176)
        at com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:106)
        at com.sun.faces.lifecycle.LifecycleImpl.phase(LifecycleImpl.java:251)
        at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:144)
        at javax.faces.webapp.FacesServlet.service(FacesServlet.java:245)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
        at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:178)
        at org.ajax4jsf.webapp.BaseFilter.handleRequest(BaseFilter.java:290)
        at org.ajax4jsf.webapp.BaseFilter.processUploadsAndHandleRequest(BaseFilter.java:390)
        at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:517)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
        at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:390)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
        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.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:525)
        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:293)
        at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:849)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
        at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:454)
        at java.lang.Thread.run(Thread.java:619)
Sei que o problema é porque a sessão está fechada. Mas não sei como corrigir. Para recuperar o objeto "OrdemServico" utilizo o seguinte método no meu Dao:
Session session = HibernateUtility.getSession();
        Query query = session.createQuery(hql);
        List<Object> objects = query.list();
        session.close();

        return objects;

Se alguém puder me ajudar eu agradeço!!! Estou precisando muito disso!

Obs.: Não posso colocar a lista com o carregamento EAGER porque já tenho outra lista, em outro objeto, com o carregamento EAGER e o Hibernate dá "pau".

Desde já agradeço! Um abraço!

4 Respostas

webdouglas

O problema é que quando tenta acessar a lista lazy, a session ja esta fechada e com isso a proxy não esta carregada.

Uma solução para o problema seria utilizar o Hibernate.initialize( objeto.getList() ) antes de fechar a session.

Uma dúvida: Esta utilizando EJB ? ou é uma aplicação desktop ?
pois caso seja EJB não há a necessidade de fechar a session o container gerenciaria isso pra vc

webdouglas

só não esqueça que no seu caso teria que percorrer a lista de resultado e aplicar o initialize para cada objeto em sua lista de resultados
algo do tipo:

List<Object> objects = query.list();  
for o:objects 
   Hibernate.initialize(o.getlist1())
   Hibernate.initialize(o.getlist2())

douglaspaulino:
O problema é que quando tenta acessar a lista lazy, a session ja esta fechada e com isso a proxy não esta carregada.

Uma solução para o problema seria utilizar o Hibernate.initialize( objeto.getList() ) antes de fechar a session.

Uma dúvida: Esta utilizando EJB ? ou é uma aplicação desktop ?
pois caso seja EJB não há a necessidade de fechar a session o container gerenciaria isso pra vc

Dassayev

Valeu pessoal! A dica de vocês foi certeira! rsrsrsrs!!!

Muito obrigado!

bfilardi

Pessoal,

Outra solução que eu descobri aqui também é a seguinte.

No meu caso estou fazendo o mapeamento do Hibernate 3 com arquivos XML (hbm.xml). No atributo em questão que vc quiser utilizar basta colocar a definição lazy=“false”.

<?xml version="1.0"?> [b] [/b]
Criado 21 de julho de 2010
Ultima resposta 5 de nov. de 2010
Respostas 4
Participantes 3