Como verificar se usuário já foi cadastrado no banco de dados? – java jdbc

Pergunta:


Como posso verificar se usuário já está cadastrado? Por exemplo,
ao cadastrar um usuário verificar se o login já foi salvo no BD.
A DAO ficou assim:

public boolean validarLogin (String login) throws SQLException, ClassNotFoundException {
    boolean existe = false;
    Pessoa p =null;
    PreparedStatement st=null;
    this.conn=new ConnectionFactory().getConnectionFactory();
    String sql = ("SELECT login FROM pessoa WHERE login = ?");
    ResultSet rs = st.executeQuery();
    while(rs.next()){
        String loginBanco = rs.getString("login");
        if (loginBanco.equals("login")){
            existe = true;
            st.close();
        }
        else {
            JOptionPane.showMessageDialog(null, "Usuário" + login + "existente");
        }
    }
    return existe;
}

O que vocês acham, é isso mesmo?

Autor da pergunta elbenevides

Resposta Valdeir Psr:

Utilize o PreparedStatment quando sua query tiver "?"

PreparedStatement statement =  this.conn.prepareStatement("SELECT login FROM pessoa WHERE login = ?");    
statement.setString(1, login);    
ResultSet rs = statement.executeQuery();

No seu código, você já está utilizando, porém está tentando executar a query em uma variável nula.

Seu código tem alguns problemas. Primeiro, não misture lógica de visualização JOptionPane com lógica de banco de dados.

Considerando que a sua classe ConnectionFactory é a desta questão, ela têm sérios problemas no gerenciamento da conexão. Vou consertá-la com base no que fiz nessa outra resposta aqui e também nessa:

package dao;
import java.sql.DriverManager;
import java.sql.SQLException;

public final class ParametrosDeConexao {
    private final String url;
    private final String usuario;
    private final String senha;

    public ParametrosDeConexao(String url, String usuario, String senha) {
        this.url = url;
        this.usuario = usuario;
        this.senha = senha;
    }

    public Connection conectar() throws SQLException {
        return DriverManager.getConnection(url, usuario, senha);
    }
}

Com isso, seu código fica que nem esse abaixo. Observe que o campo CONECTAR representa o que era sua classe ConnectionFactory:

private static final ParametrosDeConexao CONECTAR =
        new ParametrosDeConexao( 
                "jdbc:postgresql://localhost:5432/topografiaJava",
                "postgres",
                "1");

private static final String LOGIN_SQL =
        "SELECT login FROM pessoa WHERE login = ?";

public boolean validarLogin(String login) throws SQLException {
    try (
        Connection c = CONECTAR.conectar();
        PreparedStatement ps = c.prepareStatement(LOGIN_SQL)
    ) {
        ps.setString(1, login);
        try (ResultSet rs = st.executeQuery()) {
            return rs.next();
        }
    }
}

Observe como o método validarLogin(String) ficou bastante enxuto. Para isso:

  • Lembre-se de usar o try-with-resources. A menos que você esteja trabalhando com o Java 6 ou anterior, NUNCA deixe de utilizá-lo com Connection, PreparedStatement ou ResultSet.

  • Lembre-se de preencher os parâmetros do PreparedStatement adequadamente (com o setString(1, login) neste caso.

  • O return rs.next(); vai dar o true ou false que você quer dependendo se há ou não resultado no ResultSet. No seu caso, é desnecessário ler esse resultado.

  • O Class.forName não é mais necessário. Veja mais sobre isso aqui.

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *