Boa noite pessoal estou com dificuldades em uma consulta oa banco o JDBC não consegue recuperar ela dados de duas tabelas.
vejam minha casse DAO ai
package br.com.drograria.dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import br.com.drogaria.domain.Fabricante;
import br.com.drogaria.domain.Produto;
import br.com.drograria.factory.ConexaoFactory;
public class ProdutoDAO {
Connection con = ConexaoFactory.getConnection();
public void salvar(Produto produto) throws SQLException {
String sql = "INSERT INTO produto (descricao, quantidade, preco, fabricante_codigo) VALUES(?,?,?,?)";
PreparedStatement stm = con.prepareStatement(sql);
stm.setString(1, produto.getDescricao());
stm.setInt(2, produto.getQuantidade());
stm.setDouble(3, produto.getPreco());
stm.setLong(4, produto.getFabricante().getCodigo());
stm.executeUpdate();
stm.close();
}
public ArrayList<Produto> listar() throws SQLException {
String sql ="SELECT p.codigo, p.descricao, p.preco, p.quantidade, f.codigo, f.descricao FROM produto p INNER JOIN fabricante f ON f.codigo = p.fabricante_codigo ";
PreparedStatement stm = con.prepareStatement(sql);
ResultSet rs = stm.executeQuery();
ArrayList<Produto> itens = new ArrayList<Produto>();
while (rs.next()) {
Fabricante f = new Fabricante();
f.setCodigo(rs.getInt("f.numero"));
f.setDescricao(rs.getString("f.descricao"));
Produto p = new Produto();
p.setCodigo(rs.getInt("codigo"));
p.setDescricao(rs.getString("descricao"));
p.setPreco(rs.getDouble("preco"));
p.setQuantidade(rs.getInt("quantidade"));
// p.setFabricante(f);
itens.add(p);
}
return itens;
}
}
veja minha calsse teste
package br.com.drogaria.test;
import java.sql.SQLException;
import java.util.ArrayList;
import org.junit.Test;
import br.com.drogaria.domain.Fabricante;
import br.com.drogaria.domain.Produto;
import br.com.drograria.dao.ProdutoDAO;
public class ProdutoDAOTest {
@Test
@org.junit.Ignore
public void salvar()throws SQLException{
Produto p = new Produto();
p.setDescricao("Anador");
p.setPreco(3.00);
p.setQuantidade(16);
Fabricante f = new Fabricante();
f.setCodigo(4);
p.setFabricante(f);
ProdutoDAO dao = new ProdutoDAO();
dao.salvar(p);
}
@Test
public void listar() throws SQLException{
ProdutoDAO dao = new ProdutoDAO();
ArrayList<Produto> lista = dao.listar();
/* for(Produto p: lista){
System.out.println("Codigo"+ p.getCodigo());
System.out.println("Descrição "+ p.getDescricao());
System.out.println("Preço "+ p.getPreco());
System.out.println("Quatindade"+ p.getCodigo());
}*/
}
}
o erro que estou tendo
Ha lembrando eu já testei o comando sql no banco e funciona normal.
org.postgresql.util.PSQLException: A nome da coluna f.numero não foi encontrado neste ResultSet.
at org.postgresql.jdbc2.AbstractJdbc2ResultSet.findColumn(AbstractJdbc2ResultSet.java:2803)
at org.postgresql.jdbc2.AbstractJdbc2ResultSet.getInt(AbstractJdbc2ResultSet.java:2664)
at br.com.drograria.dao.ProdutoDAO.listar(ProdutoDAO.java:42)
at br.com.drogaria.test.ProdutoDAOTest.listar(ProdutoDAOTest.java:33)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)