Pessoal.
Sou iniciante em java. Já li diversos materiais sobre orientação a objetos e conceitos básicos da linguagem. Estou tentando desenvolver, de início, uma simples página que me liste todos os dados de uma determinada tabela que eu já possuo criada no postgresql.
Criei o modelo, o bean, a classe de conexão e um simples jsp que deveria listar as localidades que existem em minha tabela. Procurei no google e também aqui nos fóruns do guj algo que me ajudasse, mas não consegui êxito em sanar o meu problema. O fato é que, quando executo, a página jsp aparece somente com os títulos da h:datatable, mas sem os dados da minha tabela, a qual já está populada.
Estou utilizando o eclipse indigo, tomcat 7.0 e jsf 2.0.
Para falar bem a verdade, não sei nem como debugar o código no eclipse para verificar se é de fato o bean que não está retornando meus dados (bem coisa de iniciante mesmo).
Qualquer ajuda é bem vinda. Passo, logo abaixo, os códigos das classes a que me referi e aproveito para agradecer desde já a todos.
O modelo:
package br.com.copel.ldi.modelo;
public class Localidade {
private long cod_localidade;
private String sigla_localidade;
private String municipio;
private String localidade;
private String ag;
private String dsm;
public Localidade(){
}
public long getCod_localidade() {
return cod_localidade;
}
public void setCod_localidade(long cod_localidade) {
this.cod_localidade = cod_localidade;
}
public String getSigla_localidade() {
return sigla_localidade;
}
public void setSigla_localidade(String sigla_localidade) {
this.sigla_localidade = sigla_localidade;
}
public String getMunicipio() {
return municipio;
}
public void setMunicipio(String municipio) {
this.municipio = municipio;
}
public String getLocalidade() {
return localidade;
}
public void setLocalidade(String localidade) {
this.localidade = localidade;
}
public String getAg() {
return ag;
}
public void setAg(String ag) {
this.ag = ag;
}
public String getDsm() {
return dsm;
}
public void setDsm(String dsm) {
this.dsm = dsm;
}
}
A conexão:
package br.com.copel.ldi.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class ConnectionFactory {
public Connection getConnection() {
System.out.println("Conectando ao banco");
try {
return DriverManager.getConnection(
"jdbc:postgresql://localhost:5432/LDI", "postgres",
"postgres");
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
O bean:
package br.com.copel.ldi.bean;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import br.com.copel.ldi.jdbc.ConnectionFactory;
import br.com.copel.ldi.modelo.Localidade;
public class LocalidadeBean {
private Connection connection;
public LocalidadeBean() {
this.connection = new ConnectionFactory().getConnection();
}
public List<Localidade> getLista(){
try { List<Localidade> localidades = new ArrayList<Localidade>();
PreparedStatement stmt = connection.prepareStatement("select * from tbllocalidade");
ResultSet rs = stmt.executeQuery();
while (rs.next()) {
Localidade localidade = new Localidade();
localidade.setCod_localidade(rs.getLong("cod_localidade"));
localidade.setSigla_localidade(rs.getString("sigla_localidade"));
localidade.setMunicipio(rs.getString("municipio"));
localidade.setLocalidade(rs.getString("localidade"));
localidade.setAg(rs.getString("ag"));
localidade.setDsm(rs.getString("dsm"));
localidades.add(localidade);
}
rs.close();
stmt.close();
return localidades;
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
A view (jsp)
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@ taglib prefix="f" uri="http://java.sun.com/jsf/core"%>
<%@ taglib prefix="h" uri="http://java.sun.com/jsf/html"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Listagem de localidades</title>
</head>
<body>
<f:view>
<h:dataTable var="obj" value="#{localidadeBean.Lista}" border="1">
<h:column>
<f:facet name="header">
<h:outputText value="Código"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Cod_localidade}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Sigla"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Sigla_localidade}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Município"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Municipio}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Localidade"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Localidade}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Agência"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Ag}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="DSM"></h:outputText>
</f:facet>
<h:outputText value="#{obj.Dsm}" />
</h:column>
</h:dataTable>
</f:view>
</body>
</html>