[RESOLVIDO] problema com createSQLQuery não retorna certo

Galera, não sei se estou fazendo o correto, mas gostaria de fazer a seguinte consulta.

public List<Object[]> obtenhaProdutos(boolean tipo) { List<Object[]> resul = session.createSQLQuery("SELECT produto.idproduto,produto.nome,marca.nome,produto.valor,produto.medida FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo).list(); for(int x=0;x<resul.size();x++){ System.out.println("ID \n"+resul.get(x)[0]); System.out.println("PRODUTO NOME \n"+resul.get(x)[1]); System.out.println("MARCA NOME \n"+resul.get(x)[2]); System.out.println("VALOR \n"+resul.get(x)[3]); System.out.println("UNIDADE \n"+resul.get(x)[4]); } return resul; }

Porem o resultado é esse:

Em vez de ele me trazer o nome da marca, ele me retorna o nome do produto. o.O

O que há errado ??

Valeu

cara,

pq vc nao usa HQL,pq essa sua consulta é simples
segue como deve ficar

select p from Produto p join fetch p.marca where p.ativo = :ativo

ja te traz a lista certinha.

t+

[quote=alissonvla]cara,

pq vc nao usa HQL,pq essa sua consulta é simples
segue como deve ficar

select p from Produto p join fetch p.marca where p.ativo = :ativo

ja te traz a lista certinha.

t+[/quote]

Boa tarde alissonvla

Primeiramente obrigado pela atenção.

Então eu fazia assim, porem a consulta estava demorando 4 segundos, com 3 mil produtos o.O, na tela onde vou chamar essa consulta só preciso das colunas que eu passo no sql ali, ja fiz os testes e o tempo de reposta vai ser de menos de 1 segundo, Por isso gostaria de fazer assim.
Tem alguma idéia ?

Valeu!

Coloca um alias para as colunas produto.nome,marca.nome, veja que ambas são “nome”.

ayslanms
Obrigado pela atenção, desde cedo estou pesquisando sobre isso, porem os exemplos que encontrei , não consegui implementar, teria algum que funcione ai??

Valeu!

cara,

vc tem que ver se o JPA esta criando uma sql mais complexa para essa sua consulta.

mas indo pelo raciocinio do ayslanms, basta fazer o seguinte

List<Object[]> resul = session.createSQLQuery("SELECT produto.idproduto as ID_PRODUTO, produto.nome as NOME_PRODUTO,marca.nome as NOME_MARCA,produto.valor as VALOR,produto.medida as MEDIDA FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo).list();

t+

[quote=alissonvla]cara,

vc tem que ver se o JPA esta criando uma sql mais complexa para essa sua consulta.

mas indo pelo raciocinio do ayslanms, basta fazer o seguinte

List<Object[]> resul = session.createSQLQuery("SELECT produto.idproduto as ID_PRODUTO, produto.nome as NOME_PRODUTO,marca.nome as NOME_MARCA,produto.valor as VALOR,produto.medida as MEDIDA FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo).list();

t+[/quote]

Então, ja tinha feito dessa maneira ‘apelidando’ as colunas no resultado, porem funciona executando direto no mysql, e no java me retorna esse erro:
org.hibernate.exception.SQLGrammarException: could not execute query

coloca o log do erro completo ai

cara, coloquei try catch e ele só me retorna isso.

log4j:WARN No appenders could be found for logger (org.hibernate.cfg.annotations.Version). log4j:WARN Please initialize the log4j system properly. org.hibernate.exception.SQLGrammarException: could not execute query CONSTRUÍDO COM SUCESSO (tempo total: 2 segundos)

:S

cara,

coloque o printstacktrace no seu catch para monstrar o erro completo.

t+

Se você diz que a query da String:

"SELECT produto.idproduto as ID_PRODUTO, produto.nome as NOME_PRODUTO,marca.nome as NOME_MARCA,produto.valor as VALOR,produto.medida as MEDIDA FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo

funciona executando direto no banco, então o problema pode está nesse parametro que você está passando WHERE produto.ativo="+tipo.
tenta executar tirando esse WHERE.
Outra coisa, utiliza PreparedStatement para passar o parâmetro tipo (é mais seguro e evita SQL injections).

run: log4j:WARN No appenders could be found for logger (org.hibernate.cfg.annotations.Version). log4j:WARN Please initialize the log4j system properly. 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.custom.CustomLoader.list(CustomLoader.java:289) at org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1695) at org.hibernate.impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142) at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152) at modelo.dao.ProdutoDao.obtenhaProdutos(ProdutoDao.java:48) at classes.Utilitarios.carregaProdutos(Utilitarios.java:170) at classes.Utilitarios.main(Utilitarios.java:174) Caused by: java.sql.SQLException: Column 'idproduto' not found. at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1075) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:989) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:984) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:929) at com.mysql.jdbc.ResultSetImpl.findColumn(ResultSetImpl.java:1144) at com.mysql.jdbc.ResultSetImpl.getInt(ResultSetImpl.java:2813) at org.hibernate.type.IntegerType.get(IntegerType.java:28) at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:163) at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:189) at org.hibernate.loader.custom.CustomLoader$ScalarResultColumnProcessor.extract(CustomLoader.java:474) at org.hibernate.loader.custom.CustomLoader$ResultRowProcessor.buildResultRow(CustomLoader.java:420) at org.hibernate.loader.custom.CustomLoader.getResultColumnOrRow(CustomLoader.java:317) at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:606) at org.hibernate.loader.Loader.doQuery(Loader.java:701) at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236) at org.hibernate.loader.Loader.doList(Loader.java:2220) ... 9 more

TABELA PRODUTO:

CONSULTA FUNCIONANDO NO MYSQL:

Obrigado pela atenção

Será que não faltou o Alias de Produto?

"FROM produto produto"

cara,

vc tem certeza que vc ta fazendo essa consulta na msm base, pq ai ta falando que a coluna idProduto nao existe.

t+

Sim, estou na base correta, tanto que a query que passei no inicio do topico funciona.

 List&lt;Object[]&gt; resul = session.createSQLQuery("SELECT produto.idproduto,produto.nome,marca.nome,produto.valor,produto.medida FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo).list(); 

Se eu alterar a query colocando a marca.nome antes do produto.nome, em vez de me retornar o nome do produto, ele retorna o nome da marca o.O

List&lt;Object[]&gt; resul = session.createSQLQuery("SELECT produto.idproduto,marca.nome,produto.nome,produto.valor,produto.medida FROM produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo).list(); 

Muito esquisito :S

Coloca o Alias da tabela Produto:

"SELECT produto.idproduto as ID_PRODUTO, produto.nome as NOME_PRODUTO,marca.nome as NOME_MARCA,produto.valor as VALOR,produto.medida as MEDIDA FROM produto produto join marca on marca.idmarca=produto.idmarca WHERE produto.ativo="+tipo  

continuou o mesmo erro, dizendo que não tinha o idproduto.

Porem resolvi da seguinte forma.

Alterei o nome da coluna no banco de nome para marca
em vez de usar agora marca.nome
uso marca.marca, e funciona

ficou assim:

 List&lt;Object[]&gt; resul = session.createSQLQuery("SELECT idproduto, nome ,marca.marca,valor,medida FROM produto join marca on marca.idmarca=produto.idmarca WHERE ativo="+tipo).list(); 

Bem Estranho ^^, sera um bug ? ou está não é a forma correta? :S fica ai a duvida ahwuehawuew

Muito, mas muito obrigado mesmo pela atenção.

Abraço