[RESOLVIDO] Problema com @Formula e List<>!

1 resposta
Kleber-rr

Olá pessoal, estou tendo problemas em exibir uma lista.

- Tenho duas classes relacionadas em 1:n (movimentofinanceiro : lancamento, respectivamente); - Na classe movimentofinanceiro tenho uma variavel com a seguinte anotação:
@Formula(value = "(select (select sum(v.valor) from lancamento v where v.tipolancamento ='entrada' and v.financeiro = this_.id_movimentofinanceiro) - (select sum(v.valor) from lancamento v where v.tipolancamento ='saida' and v.financeiro = this_.id_movimentofinanceiro) ) ")
	@Column(name = "saldo")
	private Double saldo;

@OneToMany(mappedBy = "movimentofinanceiro", fetch = FetchType.LAZY)
	private List&lt;Lancamento&gt; lancamentos = new ArrayList&lt;Lancamento&gt;();
- Na classe lancamento, tenho o outro lado do relacionamento:
@ManyToOne
	@JoinColumn(name = "financeiro")
	private MovimentoFinanceiro movimentofinanceiro;
No bean de lancamento, eu solicito uma simples lista baseada num dao genérico:
public List&lt;Lancamento&gt; getLancamentos() {
		System.out.println("lendo lancamentos ...");
		Session session = HibernateUtil.currentSession();
		Dao&lt;Lancamento&gt; lancamentoDao = new Dao&lt;Lancamento&gt;(session,
				Lancamento.class);
		return lancamentoDao.list();
	}
O dao genérico:
@SuppressWarnings("unchecked")
	public List&lt;T&gt; list() {
		logger.info("Listando todos");
		return session.createCriteria(persistentClass).list();
	}
e por fim, o xhtml que eu peço a lista:
&lt;rich:dataTable value="#{lancamentoBean.lancamentos}" var="f" rendered="#{not empty lancamentoBean.lancamentos}" rows="5" id="lancamentos"&gt;
...
O problema, é que quando eu mando abrir a pagina que tem o include com a lista, ele me dá o seguinte erro:
javax.faces.FacesException: javax.el.ELException: /pages/lancamento/lista.xhtml @16,142 rendered="#{not empty lancamentoBean.lancamentos}": Error reading 'lancamentos' on type br.com.swej.bean.LancamentoBean
	at javax.faces.component.UIComponentBase.isRendered(UIComponentBase.java:373)
	at javax.faces.component.UIComponent.encodeAll(UIComponent.java:880)
	at javax.faces.render.Renderer.encodeChildren(Renderer.java:137)
	at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:809)
	at org.ajax4jsf.renderkit.RendererBase.renderChild(RendererBase.java:282)
	at org.ajax4jsf.renderkit.RendererBase.renderChildren(RendererBase.java:262)
	at org.richfaces.renderkit.html.PanelRenderer.doEncodeChildren(PanelRenderer.java:199)
	at org.richfaces.renderkit.html.PanelRenderer.doEncodeChildren(PanelRenderer.java:194)
	at org.ajax4jsf.renderkit.RendererBase.encodeChildren(RendererBase.java:121)
	at javax.faces.component.UIComponentBase.encodeChildren(UIComponentBase.java:809)
	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:809)
	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:594)
	at org.ajax4jsf.application.ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:108)
	at org.ajax4jsf.application.AjaxViewHandler.renderView(AjaxViewHandler.java:237)
	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.BaseFilter.doFilter(BaseFilter.java:307)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
	at org.ajax4jsf.webapp.BaseXMLFilter.doXmlFilter(BaseXMLFilter.java:141)
	at org.ajax4jsf.webapp.BaseFilter.doFilter(BaseFilter.java:281)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
	at br.com.swej.util.HibernateSessionFilter.doFilter(HibernateSessionFilter.java:23)
	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.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(Thread.java:636)
Caused by: javax.el.ELException: /pages/lancamento/lista.xhtml @16,142 rendered="#{not empty lancamentoBean.lancamentos}": Error reading 'lancamentos' on type br.com.swej.bean.LancamentoBean
	at com.sun.facelets.el.TagValueExpression.getValue(TagValueExpression.java:76)
	at javax.faces.component.UIComponentBase.isRendered(UIComponentBase.java:370)
	... 43 more
Caused by: org.hibernate.exception.SQLGrammarException: could not execute query
	at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:67)
	at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
	at org.hibernate.loader.Loader.doList(Loader.java:2223)
	at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2104)
	at org.hibernate.loader.Loader.list(Loader.java:2099)
	at org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:94)
	at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1569)
	at org.hibernate.impl.CriteriaImpl.list(CriteriaImpl.java:283)
	at br.com.swej.dao.Dao.list(Dao.java:38)
	at br.com.swej.bean.LancamentoBean.getLancamentos(LancamentoBean.java:40)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:616)
	at javax.el.BeanELResolver.getValue(BeanELResolver.java:62)
	at javax.el.CompositeELResolver.getValue(CompositeELResolver.java:53)
	at com.sun.faces.el.FacesCompositeELResolver.getValue(FacesCompositeELResolver.java:64)
	at org.apache.el.parser.AstValue.getValue(AstValue.java:118)
	at org.apache.el.parser.AstEmpty.getValue(AstEmpty.java:45)
	at org.apache.el.parser.AstNot.getValue(AstNot.java:42)
	at org.apache.el.ValueExpressionImpl.getValue(ValueExpressionImpl.java:186)
	at com.sun.facelets.el.TagValueExpression.getValue(TagValueExpression.java:71)
	... 44 more
Caused by: com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: Unknown column 'this_.id_movimentofinanceiro' in 'where clause'
	at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:936)
	at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)
	at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631)
	at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723)
	at com.mysql.jdbc.Connection.execSQL(Connection.java:3256)
	at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1313)
	at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1448)
	at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeQuery(NewProxyPreparedStatement.java:76)
	at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:186)
	at org.hibernate.loader.Loader.getResultSet(Loader.java:1787)
	at org.hibernate.loader.Loader.doQuery(Loader.java:674)
	at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236)
	at org.hibernate.loader.Loader.doList(Loader.java:2220)
	... 63 more

O erro me retorna um problema na síntese da clausula where referente a coluna this_.id_movimentofinanceiro. O problema é que essa clausula estou usando em outra classe que é relacionada com a classe lancamento (o relacionamento que mencionei antes...). Se eu tirar a anotacao @Formula, a pagina abre normalmente...

Alguem pode me ajudar a resolver isso sem que eu tire essa anotação?? ou uma alternativa para a anotacao @Formula??

Agradeço pessoal.

1 Resposta

Kleber-rr

Resolvido! Tirei o “this_.” da anotação e ficou tudo certo.
Quanto à sugestão para substituir o @Formula, quem tiver, pode postar.

Vlw.

Criado 26 de abril de 2010
Ultima resposta 26 de abr. de 2010
Respostas 1
Participantes 1