• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Sprawdzanie czy nazwa użytkownika jest już zajęta w PDO

0 głosów
481 wizyt
pytanie zadane 26 lutego 2017 w PHP przez Laxus Początkujący (280 p.)
require_once 'connect.php';
				$pdo = new PDO( "mysql:host = $database_host; dbname = logowanie; encoding = utf8", "$database_user", "$database_password", array( PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8' ) );
				$pdo -> setAttribute( PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC );

				$loginCheck = $pdo -> prepare( "SELECT COUNT(*) FROM 'users' WHERE login = :login" );
				$loginCheck -> bindParam( ':login', $login );
				$loginCheck -> execute();
		
				if( $loginCheck -> fetchColumn() > 0) {

					$validate = false;
					$_SESSION[ 'loginError' ] = 'Wprowadzony login jest już zajęty.';
					header( 'Location: rejestracja.php' );
				} else { echo 'OK '; }

Może mi ktoś wytłumaczyć dlaczego zawsze zwracane mam OK? Nawet jak już istnieje taki login w bazie.

Pierwszy raz używam PDO i nie potrafię ogarnąć jak sprawdzić czy podany w formularzu login jest już w bazie. Niby wygooglować można, wszystko opisane, ale i tak zawsze coś nie chodzi angry

1 odpowiedź

0 głosów
odpowiedź 26 lutego 2017 przez Assasz Nałogowiec (30,460 p.)

Możesz to sprawdzić za pomocą funkcji rowCount().

Podobne pytania

0 głosów
1 odpowiedź 1,570 wizyt
pytanie zadane 21 marca 2017 w PHP przez prymex Obywatel (1,250 p.)
0 głosów
2 odpowiedzi 859 wizyt
pytanie zadane 17 kwietnia 2022 w PHP przez molik Użytkownik (950 p.)
+1 głos
1 odpowiedź 356 wizyt

93,695 zapytań

142,613 odpowiedzi

323,225 komentarzy

63,226 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...