Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php][mysql] sprawdzanie czy rekord ma odpowiednią wartość
Forum PHP.pl > Forum > Przedszkole
!*!
  1. <?php
  2. $brak = 'brak';
  3. $sprawdz = mysql_query("SELECT * FROM `userdata` WHERE `id` = '$userdata'");
  4. $wyniksprawdz = mysql_fetch_row($sprawdz);
  5.  
  6.  
  7. if ($wyniksprawdz == $brak) {
  8. echo "odpowiedni link<br />";
  9.  
  10. } else {
  11.  
  12. echo ' masz wszytkie rekordy<br />';
  13.  
  14. }
  15. ?>


w bazie userdata mam ok 1,5tys. rekordów, chciałbym sprawdzić jeśli któryś z nich ma warotść "brak" aby wyświelił się link, a jeśli każdy jest zapisany to komunikat z else... i to jest oczywiste, ale gdzieś mam tu błąd...
PawelC
Ale czego brak? w jakiej kolumnie jest ta wartość brak?
!*!
mam pole np. "kaczki" jego wartość to "czarne" albo "brak" brak w tym wypadku oznacza iż wpis o kaczkach nie ma się pokazywać i z tym sobie poradziłem, ale nie wiem jak zrobić aby były sprawdzanie wszytkie rekordy i jeśli w którynś jest wartość "brak" to zostanie wyświetlony link
Fishu
  1. <?php
  2. $brak = 'brak';
  3. $sprawdz = mysql_query("SELECT * FROM `userdata` WHERE `id` = '$userdata'");
  4.  
  5. while($wyniksprawdz = mysql_fetch_row($sprawdz));
  6. if ($wyniksprawdz == $brak) {
  7. echo "odpowiedni link<br />";
  8.  
  9. } else {
  10.  
  11. echo ' masz wszytkie rekordy<br />';
  12.  
  13. }
  14. }
  15. ?>

Sprawdź, powinno to zadziałać winksmiley.jpg
PawelC
pobierasz z bazy rekordy do pętli z warunkiem, w zapytaniu czyli where kaczki="brak", to wyświetl je przy pomocy echo
Np:
  1. <?php
  2.  
  3. $sql="SELECT kaczki FROM `userdata` WHERE `kaczki` = 'brak'";
  4. $sprawdz = mysql_query($sql);
  5.  
  6. while($wyniksprawdz = mysql_fetch_row($sprawdz)){
  7. if ($wyniksprawdz['kaczki'] == 'brak') {
  8. echo "odpowiedni link<br />";
  9.  
  10. } else {
  11.  
  12. echo ' masz wszytkie rekordy<br />';
  13.  
  14. }
  15. }
  16. ?>
!*!
Fiszu, nie działa, obojetnie jakie pole nie miałoby wartości "brak" jest wyświetlane "masz wszytkie rekordy"

ExPlOiT, emm napisałem że mam bardzo dużo pól, więc pisanie

Kod
if ($wyniksprawdz['kaczki'] == 'brak') {


dla każdego z nich mija się z celem
PawelC
to zrób tak:
  1. <?php
  2.  
  3. $sql="SELECT * FROM userdata WHERE `id` = '$userdata'";
  4. $sprawdz = mysql_query($sql);
  5.  
  6. while($wyniksprawdz = mysql_fetch_row($sprawdz)){
  7. if ($wyniksprawdz == 'brak') {
  8. echo "odpowiedni link<br />";
  9.  
  10. } else {
  11.  
  12. echo ' masz wszytkie rekordy<br />';
  13.  
  14. }
  15. }
  16. ?>
!*!
i problem jest ten sam... jeśli kilka pół ma wartość "brak" to i tak wyświetla się "masz wszytkie..."

próbowałem pozmieniać

Kod
$wyniksprawdz == 'brak'


na !==, =, != itp. ale bez skutku



EDIT:

i kurcze nie wiem... wie ktoś jak to rozwiązać?
-kapitan_hak-
Cytat(!*! @ 14.04.2008, 20:19:32 ) *
i problem jest ten sam... jeśli kilka pół ma wartość "brak" to i tak wyświetla się "masz wszytkie..."

próbowałem pozmieniać

Kod
$wyniksprawdz == 'brak'


na !==, =, != itp. ale bez skutku
EDIT:

i kurcze nie wiem... wie ktoś jak to rozwiązać?

Spróbuj:
Kod
$sql="SELECT * FROM userdata WHERE `id` = '$userdata'";
$sprawdz = mysql_query($sql);

while($wyniksprawdz = mysql_fetch_row($sprawdz)){
  foreach($wyniksprawdz as $wynik)
  {
  if ($wynik == 'brak') {
      echo "odpowiedni link<br />";

  } else {

    echo ' masz wszytkie rekordy<br />';

    }
  }
}

Sprawdzi ci to każde pole po kolei.
!*!
przy takim zastosowaniu zwraca mi "masz wszytkie rekordy" tyle ile mam pól... Nie sprawdza tego jaką mają wartość i nie wyświetla jednorozawo komunikatu, tylko teraz sprawedza jaka jest wartość i do każdego pola wyświetla osobny choć ten sam komunikat
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.