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

fetchAssoc PHP PDO

Object Storage Arubacloud
0 głosów
165 wizyt
pytanie zadane 26 stycznia 2022 w PHP przez EmilB Użytkownik (980 p.)

Cześć, nie działa mi fetchAssoc, ktoś pomoże?

<?php

	require_once("/home/******/public_html/trade/database/db.php");

	$login = "reju";

	$rezultat = $dbc->query("SELECT * FROM 'users' WHERE nick = '".$login."'");

	$liczba_userow = count($rezultat);

	echo $liczba_userow;

	$wynik = $rezultat->fetch(PDO::FETCH_ASSOC);

	echo $rezultat["nick"];

 ?>

 

1 odpowiedź

+3 głosów
odpowiedź 26 stycznia 2022 przez Comandeer Guru (601,510 p.)
wybrane 26 stycznia 2022 przez EmilB
 
Najlepsza

Co to znaczy "nie działa"? Jaki błąd się pojawia? Masz włączone wyświetlanie błędów?

Ogólnie to powinieneś używać prepared statements, dzięki czemu miałbyś o wiele lepiej ogarniętą kwestię bezpieczeństwa.

Co do problemu: zauważ, że próbujesz pobrać nick z $rezultat, a on jest "surowym" zapytaniem do bazy. Wyniki zaciągnąłeś sobie do zmiennej $wynik, więc powinieneś z niej wyciągać nick (zatem $wynik['nick']).

Niemniej to dalej prawdopodobnie nie zadziała, bo w samym zapytaniu SQL masz błąd składni – otoczyłeś nazwę tabeli w bazie w apostrofy. To oznacza, że baza traktuje users jako tekst, nie nazwę tabeli. Powinieneś albo napisać po prostu users, bez niczego, albo otoczyć nazwę tabeli w grawisy (`).

Nie da się też wywołać count na zapytaniu, możesz za to skorzystać z $rezultat->rowCount(). To powinno zwrócić Ci liczbę znalezionych wierszy. Jeśli nie działa, to najsensowniej po prostu odpytać o to bazę danych.

Nie wiem też, czemu podajesz całą ścieżkę w require_once? Ścieżka relatywna powinna działać ok.

Kod po poprawkach, o których mówiłem, powinien wyglądać mniej więcej tak:

<?php
 
    require_once("/home/******/public_html/trade/database/db.php");
 
    $login = "reju";
 
    $rezultat = $dbc->query("SELECT * FROM users WHERE nick = '".$login."'");
 
    $liczba_userow = $rezultat->rowCount();
 
    echo $liczba_userow;
 
    $wynik = $rezultat->fetch(PDO::FETCH_ASSOC);
 
    echo $wynik["nick"];
 
 ?>

Chociaż, tak jak mówię, lepiej jak najszybciej przejść na prepared statements.

komentarz 26 stycznia 2022 przez EmilB Użytkownik (980 p.)
Już sobie poradziłem ze wszystkim, wszystko działa, ale dzięki za pomoc.

Podobne pytania

+1 głos
3 odpowiedzi 422 wizyt
+1 głos
1 odpowiedź 149 wizyt
pytanie zadane 9 marca 2021 w PHP przez niezalogowany
0 głosów
0 odpowiedzi 297 wizyt
pytanie zadane 3 czerwca 2018 w PHP przez karol928 Początkujący (320 p.)

92,576 zapytań

141,426 odpowiedzi

319,651 komentarzy

61,961 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...