• Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   14-02-2016

      Prezados membros do Fórum do Clube do Hardware,

      Está aberto o processo de seleção de novos moderadores para diversos setores do fórum. Os requisitos são:
        Pelo menos 1000 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas ao formulário abaixo:    Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
Abma12

Erro no mysql_num_rows ...

6 posts neste tópico

Bem pessoal estava eu criando um sistema de login com session em php + mysql ...

Porém certa parte do php precisa do mysql_num_Rows (para verifica os usuarios no db e criar a session ... )

<?php
include "config.php";
$login = $_POST['login'];
$senha = $_POST['senha'];

$sqlc = "SELECT * FROM USERS WHERE Users = '$login' AND Senha ='$senha'";
$sqla = mysql_query($sqlc);

if(mysql_num_rows($sqla) == 1 ) {

$_SESSION['loginSession'] = $login ;
$_SESSION['senhaSession'] = $senha ;

include "Home.php";

}else{

include "Login.php";


}

Quando vou testar logando ele me devolve esse erro :

Warning: mysql_num_rows() expects parameter 1 to be resource, boolean given in C:\wamp\www\log.php on line 17 :angry:

Compartilhar este post


Link para o post
Compartilhar em outros sites

#2   Postado (editado)

O problema não é exatamente em mysql_num_rows. Tal função deve receber um recurso SQL como parâmetro, mas a consulta SQL não está retornando o recurso. Está retornando um booleano (FALSE).

Tenha certeza de que a consulta feita tem uma sintaxe válida.

Ah, e sempre escape as variáveis na string. Exemplo:


$sqlc = "SELECT * FROM users WHERE users = '". $login. "' AND senha = '". $senha ."'";

Editado por WntD

Compartilhar este post


Link para o post
Compartilhar em outros sites
O problema não é exatamente em mysql_num_rows. Tal função deve receber um recurso SQL como parâmetro, mas a consulta SQL não está retornando o recurso. Está retornando um booleano (FALSE).

Tenha certeza de que a consulta feita tem uma sintaxe válida.

Ah, e sempre escape as variáveis na string. Exemplo:


$sqlc = "SELECT * FROM users WHERE users = '". $login. "' AND senha = '". $senha ."'";

WntD, eu não sou muito experiente em php+mysql ...

Queria saber se consigo corrigir meu problema substituindo a variavel $sqlc pela a variavel que você postou ...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Como eu não conheço a tabela 'users' que você está usando no banco de dados, não tem como eu saber se substituindo a variável, irá funcionar.

Confira os nomes das colunas, o nome da tabela, e principalmente, confira se o arquivo 'config.php' estabelece uma conexão com o banco de dados MySQL. Não adianta tentar executar uma query se você sequer esta´conectado ao banco de dados. Nesses casos, mysql_query retorna um booleano FALSE também.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Como eu não conheço a tabela 'users' que você está usando no banco de dados, não tem como eu saber se substituindo a variável, irá funcionar.

Confira os nomes das colunas, o nome da tabela, e principalmente, confira se o arquivo 'config.php' estabelece uma conexão com o banco de dados MySQL. Não adianta tentar executar uma query se você sequer esta´conectado ao banco de dados. Nesses casos, mysql_query retorna um booleano FALSE também.

o config.php funciona sim, pois até uso ele na página de cadastro que funciona super bem !

O nome da tabela é USERS (na página de cadastro gravo os usuarios aqui e sempre com sucesso)

e as colonas ...

ID (Primária, AI ) Nome (VARCHAR 255) Email (VARCHAR 255) User (VARCHAR 255) e Senha (VARCHAR 255) ...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Então aparentemente o erro está na cláusula 'where'.

Se a coluna com o nome do usuario se chama 'user', você não pode colocar na consulta 'users'.

Seria


$sqlc = "SELECT * FROM users WHERE User = '". $login. "' AND Senha = '". $senha ."'";

Dessa maneira deve dar certo.

Não se esqueça de conferir as maiusculas e minusculas.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!


Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.


Entrar agora