PESSOAL NÃO CONSIGO CARREGAR MINHA HASHTABLE NA JSP SEM USAR GET E SET COM STRUTS… A PAGINA SIMPLESMENTE NÃO CARREGA NADA… ALGUEM SABE OQUE PODE SER??
DESDE JA, OBRIGADO!
1° método retorna um hashtable, a idéia é trazer uma lista com dois parametros por linha
protected static Hashtable[] selectCpfAfiliado()throws SQLException{
SQLServerConnection servConn = new SQLServerConnection();
Hashtable[] resultado = {};
String query="";
try{
query = "SELECT count(valor_string) qtde_registros, valor_string FROM"+
" retail..organizacao_cadastro_campo_extra WHERE id_campo=23 GROUP BY valor_string;";
ResultSet rs = servConn.dataLoad(query);
if(!servConn.isEmptySet()){
resultado=new Hashtable[servConn.getNRows()];
for(int i=0; i<servConn.getNRows()-1; i++){
rs.next();
if (Util.parseInt(rs.getString("qtde_registros"))>1){
resultado[i] = new Hashtable();
resultado[i].put("qtde_registros",rs.getString("qtde_registros"));
resultado[i].put("valor_string",rs.getString("valor_string"));
LogSis.logar(LogSis.LOG4J_INFO_LEVEL,"ERRO!");
}
}
}
return resultado;
}finally{
servConn.closeConnection();
}
}
Action Responsavel pela instancia do método:[code] public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
//validação de sessão
if(!ControleAnuncio.auteunticaSessao(request.getCookies(),response)){
return mapping.findForward("expira");
}
//carrega os dados
Hashtable[] listaCpf = ControleAfiliado.selectCpfAfiliado();
request.setAttribute("listaCpf",listaCpf);
return mapping.findForward("listar");
}[/code]
E por fim a JSP que não monta a lista de jeito nenhum!!
[code]<form-property name="listaCpf" type="java.util.Hashtable"/>
<logic:iterate id="it" name="listaCpf" type="com.buscape.vitrine.beans.OrganizacaoCompleta">
<tr>
<td>
<bean:write name="it" property="qtde_registros"/>
</td>
<td>
<bean:write name="it" property="valor_string"/>
</td>
</tr>
</logic:iterate>
[/code]
pq vc esta usando um array de HashTable???
pq não usa ArrayList q eh muit mais simples de manipular?
Disseram que seria melhor COM HASH, mas posso mudar isso.
Teria um exemplo basico de como ficaria com ARRAY LIST?
Pelo menos a parte da Action e da JSP…
Obrigado!
na Action a única coisa q vc muda é:
//carrega os dados
List listaCpf = ControleAfiliado.selectCpfAfiliado();
e o seu método ficará:
public static List selectCpfAfiliado()throws SQLException{
SQLServerConnection servConn = new SQLServerConnection();
List resultado = new ArrayList();
...
lembra de ao pegar o ResultSet, popular um Objeto seu mesmo acho q sera “OrganizacaoCompleta”, e vai inserindo no ArrayList…
nem precisa colocar o type do logic:iterate, mas lembrando que qtde_registros e valor_string devem ser propriedades de “OrganizacaoCompleta”…
<logic:iterate id="it" name="listaCpf" >
<tr>
<td>
<bean:write name="it" property="qtde_registros"/>
</td>
<td>
<bean:write name="it" property="valor_string"/>
</td>
</tr>
</logic:iterate>
eh legal vc dar uma estudada nas tags logic:empty e logic:notEmpty e bem útil quando vc está fazendo pesquisas assim…
espero ter ajudado…
flw
cara não entendi essa parte…
resultado.add(organizacaoCompleta);
não sei qual objeto usar… como disse só fiz iterações usando get e set…
poderia mostrar melhor a montagem do metodo pra ficar mais claro?
Obrigado!
Rodrigo.
eu não testei, fiz aqui na mão mesmo, mas eh algo assim:
public static List selectCpfAfiliado()throws SQLException{
SQLServerConnection servConn = new SQLServerConnection();
List resultado = new ArrayList();
String query="";
try{
query = "SELECT count(valor_string) qtde_registros, valor_string FROM"+
" retail..organizacao_cadastro_campo_extra WHERE id_campo=23 GROUP BY valor_string;";
ResultSet rs = servConn.dataLoad(query);
if(!servConn.isEmptySet()){
for(int i=0; i<servConn.getNRows()-1; i++){
rs.next();
if (Util.parseInt(rs.getString("qtde_registros"))>1){
OrganizacaoCompleta organizacaoCompleta = new OrganizacaoCompleta();
organizacaoCompleta.setQtde_registros(rs.getString("qtde_registros"));
organizacaoCompleta.setValor_string(rs.getString("valor_string"));
resultado.add(organizacaoCompleta);
}
}
}
return resultado;
}finally{
servConn.closeConnection();
}
OK!! mas não tenho o objeto “OrganizacaoCompleta();”
Não posso usar métodos GET e SET… a idéia é imprimir o resultado sem usar Gets e SETs…
Tem como fazer isso… desse jeito ou de outro???
Obrigado!!!
aaaaahhhhhhh
bom, eu sempre gostei de trabalhar com TOs, funciona da seguinte forma, vc monta um ObjetoTO para praticamente cada uma das suas tabelas do banco…e tb monta TOs para consultas especificas, no seu caso por exemplo OrganizacaoCompletaTO, com os campos q nos ja citamos e os getters e setters…
sem os getters e setters, acho q nao vai ser possivel usando a tag logic:iterate, pq ela itera em cima de classes q implementem a interface List, e automaticamente procura o metodo getXXX dentro de cada objeto na iteração…
se vc tem a liberdade de mudar, faz dessa forma q eu falei, pelo menos eh a melhor na minha opinião…
flw