1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Optimização Codigo 2

Bom dia! a dois dias postei um código onde fazia uma seleção básica e alguns amigos sugeriram algumas mudanças que tornariam o código mais encapsulado. Com estas novas idéias pensei, bom desta alem de passar os filtros, ordem e seleção posso passar a tabela o que tornaria meu metodo seleção genérico para qualquer uma de minhas consultas, não precisando assim criar um metodo seleção para cada uma das minhas ClassesDAO. O problema é o seguinte como posso buscar qualquer coisa o retorno para o programa que chamou é indefinido, ou seja, ou eu faria um switch e estaria a tabela para enviar os retornos ou eu passo o proprio ResultSet, ai que entra a parte conceitual da coisa. Acho que não seria elegante e nem certo retornar um ResultSet para um classe de Telas onde vou carrgar meu Jtable, ou estou errado? alguem tem alguma sugestão sobre esse assunto?

public class Selecionar {

    private Connection con;
    private MapearParametros parametros;

    public Selecionar(Connection con, MapearParametros parametros) {
        this.con = con;
        this.parametros = parametros;
    }

    public ResultSet SelecionarEstados() throws Exception {
        List<String> selecaoExiste = new ArrayList<String>();
        MontarSFO montarSFO = new MontarSFO();
        List<Estados> listaEstados = new ArrayList<Estados>();
        List<EstruturaCampos> filtros = new ArrayList<EstruturaCampos>();
        List<EstruturaCampos> selecao = new ArrayList<EstruturaCampos>();
        List<EstruturaCampos> ordem = new ArrayList<EstruturaCampos>();
        EstruturaCampos estrutura = new EstruturaCampos();
        StringBuffer sql = new StringBuffer("select");
        listaEstados.clear();
        selecaoExiste.clear();
        filtros = parametros.getFiltros();
        selecao = parametros.getSelecao();
        ordem = parametros.getOrdem();
        montarSFO.MontarSelecao(sql, estrutura, selecao, selecaoExiste);
        montarSFO.MontarFiltros(sql, estrutura, filtros, parametros.getTabela());
        montarSFO.MontarOrdem(sql, estrutura, ordem);
        PreparedStatement e = con.prepareStatement(sql.toString());
        if (filtros != null && !filtros.isEmpty()) {
            for (int i = 0; i < filtros.size(); i++) {
                estrutura = filtros.get(i);
                e.setObject(i + 1, estrutura.getValueCampo());
            }
        }
        ResultSet rs = e.executeQuery();
        return rs;
    }
}

Thiago Costa

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags otimização dao java ou faça a sua própria pergunta.