Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Jak wykryć brak wyników?, Bez użycia COUT();
8rol
post 24.06.2010, 16:03:45
Post #1





Grupa: Zarejestrowani
Postów: 66
Pomógł: 0
Dołączył: 10.10.2009

Ostrzeżenie: (0%)
-----


Witam, mam następujący problem.


W jaki sposób wykryć, że funkcja mysql_query dla danego zapytania zwraca 0 wyników?

Prosty przykład o co chodzi.

$zapytanie = mysql_query("SELECT `wiek` FROM `uczniowie` WHERE `imie` = 'Alek' LIMIT 1");

$wynik = mysql_result($check, 0);

Jeśli w tabeli `uczniowie` istnieje osoba o imieniu 'Alek' w zmiennej $wynik znajdzie się jego wiek.
Jednak jeśli w tabeli nie ma osoby o imieniu 'Alek' funkcja mysql_result nie zadziała dając komunikat: "Unable to jump to row 0 on MySQL result (..)".

Z tego tez powodu chciałbym wiedzieć czy istnieje jakiś sposób na wykrycie, że funkcja mysq_query zwraca 0 wyników.

Owszem, wiem, że mógłbym najpierw wykonać zapytanie z funkcją COUNT(), aby sprawdzić czy nie zwraca ona 0, jednak wtedy będzie potrzebne kolejne zapytanie SELECT, które dopiero pobierze `wiek`, a zależy mi żeby zapytań było raczej jak najmniej smile.gif
Go to the top of the page
+Quote Post
erix
post 24.06.2010, 16:09:58
Post #2





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Hmm, przecież jak używasz mysql_fetch_array to zwraca ona albo rekord, albo false (jeśli błąd albo nie ma rekordów).


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
8rol
post 24.06.2010, 16:28:19
Post #3





Grupa: Zarejestrowani
Postów: 66
Pomógł: 0
Dołączył: 10.10.2009

Ostrzeżenie: (0%)
-----


W zasadzie też można, ale przypomniałem sobie o funkcji mysql_num_rows , która wydaje się, że będzie do tego najlepsza smile.gif

Ten post edytował 8rol 24.06.2010, 16:28:43
Go to the top of the page
+Quote Post
Mchl
post 24.06.2010, 16:47:24
Post #4





Grupa: Zarejestrowani
Postów: 855
Pomógł: 145
Dołączył: 17.07.2008
Skąd: High Memory Area

Ostrzeżenie: (0%)
-----


Cytat(erix @ 24.06.2010, 17:09:58 ) *
Hmm, przecież jak używasz mysql_fetch_array to zwraca ona albo rekord, albo false (jeśli błąd albo nie ma rekordów).


Jeśli błąd. Jeśli nie ma rekordów zwraca pusty resultset. Wrong... z mysql_query mi się pomyliło tongue.gif

mysql_num_rows() jak najbardziej do tego jest stworzona.

Ten post edytował Mchl 24.06.2010, 16:52:52
Go to the top of the page
+Quote Post
erix
post 24.06.2010, 16:58:23
Post #5





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Cytat
W zasadzie też można, ale przypomniałem sobie o funkcji mysql_num_rows , która wydaje się, że będzie do tego najlepsza

Nie będzie najlepsza. Jeśli sprawdzamy, czy są dane, bez konieczności sprawdzenia, ile jest rekordów, mysql_num_rows OMIJAMY z daleka. O ile pamiętam, to nawet w manualu jest coś o tym napisane, ale chyba w komentarzach. Nawet jeśli jest potrzebna konkretna liczba rekordów - są inne sposoby, które są zalecane, bo mysql_num_rows jest chyba najbardziej zasobożernym sposobem.

Co nie zmienia faktu, że to logiczne - nie musisz liczyć, ile masz piłeczek w pudełku, skoro wystarczy do niego zerknąć, żebyś wiedział, że coś w nim jest. winksmiley.jpg


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
sebekzosw
post 24.06.2010, 17:40:51
Post #6





Grupa: Zarejestrowani
Postów: 437
Pomógł: 42
Dołączył: 16.04.2007

Ostrzeżenie: (0%)
-----


  1. $wyniki = mysql_fetch_assoc(mysql_query("SELECT * FROM `uczniowie` WHERE `imie` LIKE 'Alek' LIMIT 1;"));
  2.  
  3. if(!empty($wyniki))
  4. {
  5. //instrukcje wykonywane, jeżeli nie jest pusta tablica $wyniki
  6. }


Ten post edytował sebekzosw 24.06.2010, 17:48:37
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 06:42