Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Co jest złego w tym warunku?
Bilbosz
post
Post #1





Grupa: Zarejestrowani
Postów: 5
Pomógł: 0
Dołączył: 12.03.2017

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


Witam. Potrzebuję porównać 2 dane z tabeli w warunku. Problem polega na tym, że warunek nie działa jak trzeba.

  1. $exp = $m -> query('SELECT exp FROM gracze WHERE id = '.$_SESSION['id'].' LIMIT 1');
  2. $exp_max = $m -> query('SELECT exp_max FROM gracze WHERE id = '.$_SESSION['id'].' LIMIT 1');
  3.  
  4. if(mysqli_num_rows($exp) > mysqli_num_rows($exp_max)){
  5. $m -> query('UPDATE gracze SET exp = 0 WHERE id = '.$_SESSION['id'].' LIMIT 1');
  6. $m -> query('UPDATE gracze SET poziom = poziom + 1 WHERE id = '.$_SESSION['id'].' LIMIT 1');
  7. }
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
trueblue
post
Post #2





Grupa: Zarejestrowani
Postów: 6 806
Pomógł: 1828
Dołączył: 11.03.2014

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


Obydwa zapytania zwracają taką samą ilość rekordów (0 lub 1) i porównujesz ilość, a nie wartości.
Pobierz wartości (jednym zapytaniem) i porównaj. Możesz też zrobić porównanie bezpośrednio w zapytaniu.
Go to the top of the page
+Quote Post
Bilbosz
post
Post #3





Grupa: Zarejestrowani
Postów: 5
Pomógł: 0
Dołączył: 12.03.2017

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


Cytat(trueblue @ 12.03.2017, 15:11:20 ) *
Obydwa zapytania zwracają taką samą ilość rekordów (0 lub 1) i porównujesz ilość, a nie wartości.
Pobierz wartości (jednym zapytaniem) i porównaj. Możesz też zrobić porównanie bezpośrednio w zapytaniu.


Jestem w tym zielony. Jakoś tak to powinno wyglądać(IMG:style_emoticons/default/questionmark.gif)

  1. //kolejny poziom
  2. $z = $m -> query('SELECT exp, exp_max FROM gracze WHERE id = '.$_SESSION['id'].' LIMIT 1');
  3.  
  4. while($w = $z -> fetch_assoc()){
  5. if($w['exp'] >= $w['$exp_max']){
  6. $m -> query('UPDATE gracze SET exp = 0 WHERE id = '.$_SESSION['id'].' LIMIT 1');
  7. $m -> query('UPDATE gracze SET poziom = poziom + 1 WHERE id = '.$_SESSION['id'].' LIMIT 1');
  8. }
  9. }
Go to the top of the page
+Quote Post

Posty w temacie


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

 



RSS Aktualny czas: 3.10.2025 - 16:13