Pessoal não estou conseguindo executar uma logica para que quando minha paginas JSP de busca executa a logica de busca no meu DAO e exiba em uma pagina JSP o resultado desta busca especifica… Se você puderem me ajudar usei como exemplo a agenda da apostila da caelum do fj-21,
A questao é o seguinte não consigo fazer com que esta minha JSP de busca realize o metodo de busca do ContatosDAO e mostre em uma JSP.
Vocês poderiam me socorrer?
ContatosDAO
package br.com.caelum.agenda.dao;
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.caelum.agenda.ConnectionFactory;
import br.com.caelum.agenda.modelo.Contato;
public class ContatoDAO {
private Connection connection;
public ContatoDAO() {
try{
this.connection = new ConnectionFactory().getConnection();
} catch (SQLException e){
throw new RuntimeException(e);
}
}
public void adiciona(Contato contato) {
String sql = "insert into contatos (nome, email, endereco) values (?,?,?)";
try {
PreparedStatement stmt = connection.prepareStatement(sql);
stmt.setString(1, contato.getNome());
stmt.setString(2, contato.getEmail());
stmt.setString(3, contato.getEndereco());
//stmt.setDate(4, new Date(contato.getDataNascimento().getTimeInMillis()));
stmt.execute();
stmt.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
// deixei como comentario pra testar a lista de busca
public List<Contato> getLista() {
try {
List<Contato> contatos = new ArrayList<Contato>();
PreparedStatement stmt = this.connection.prepareStatement("select * from contatos");
ResultSet rs = stmt.executeQuery();
while(rs.next()) {
Contato contato = new Contato();
//popula o objeto contato
contato.setId(rs.getLong("id"));
contato.setNome(rs.getString("nome"));
contato.setEmail(rs.getString("email"));
contato.setEndereco(rs.getString("endereco"));
/*
//popula a data de nascimento do contato, fazendo a conversao
Calendar data = Calendar.getInstance();
data.setTime(rs.getDate("dataNascimento"));
contato.setDataNascimento(data);
*/
//deixado como comentario pra testar a lista de busca
//adiciona o contato na lista
contatos.add(contato);
}
rs.close();
stmt.close();
return contatos;
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
// lista de busca
public void busca(Contato contato) {
String sql = "select * from contatos where id=?";
try {
PreparedStatement stmt = this.connection.prepareStatement(sql);
stmt.setLong(1, contato.getId());
stmt.execute();
stmt.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
public void altera(Contato contato) {
String sql = "update contatos set nome=?, email=?, endereco=? where id=?";
try {
PreparedStatement stmt = connection.prepareStatement(sql);
stmt.setString(1, contato.getNome());
stmt.setString(2, contato.getEmail());
stmt.setString(3, contato.getEndereco());
stmt.setLong(4, contato.getId());
stmt.execute();
stmt.execute();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
está é a minha jsp que adiciona contatos
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<?xml version="1.0" encoding="ISO-8859-1" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>adiciona-contato.html</title>
</head>
<body>
<c:import url="cabecalho.jsp" />
<form action="adicionaContato" method="post">
<center> Nome: <input type="text" name="nome" /><br /></center>
<center> E-mail: <input type="text" name="email" /><br /> </center>
<center> Endereço: <input type="text" name="endereco" /><br /></center>
<center> <input type="submit" value="Gravar" /></center>
</form>
<c:import url="rodape.jsp" />
</body>
</html>
ESTÁ É A JSP QUE EXIBE A RELACAO DE TODOS CONTATOS NO BANCO
<?xml version="1.0" encoding="ISO-8859-1" ?>
<%@ page import="java.util.*,br.com.caelum.agenda.dao.*"%>
<%@ page import="br.com.caelum.agenda.modelo.*"%>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>Insert title here</title>
</head>
<body>
<table>
<%
ContatoDAO dao = new ContatoDAO();
List<Contato> contatos = dao.getLista();
for (Contato contato : contatos ) {
%>
<tr>
<td><%=contato.getNome() %></td>
<td><%=contato.getEmail() %></td>
<td><%=contato.getEndereco() %></td>
</tr>
<%
}
%>
</table>
</body>
</html>
criei uma jsp que receba os parametros da busca:
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<?xml version="1.0" encoding="ISO-8859-1" ?>
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" />
<title>busca-contato</title>
</head>
<body>
<c:import url="cabecalho.jsp" />
<form action="buscaContato" method="post">
<center>Nome: <input type="text" name="nome"/><br /> </center>
<center> <input type="submit" value="Buscar" /></center>
</form>
<c:import url="rodape.jsp" />
</body>
</html>
A questao é o seguinte não consigo fazer com que esta minha JSP de busca realize o metodo de busca do ContatosDAO e mostre em uma JSP.
Vocês poderiam me socorrer?