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ć

//kolejny poziom
$z = $m -> query('SELECT exp, exp_max FROM gracze WHERE id = '.$_SESSION['id'].' LIMIT 1');
while($w = $z -> fetch_assoc()){
if($w['exp'] >= $w['$exp_max']){
$m -> query('UPDATE gracze SET exp = 0 WHERE id = '.$_SESSION['id'].' LIMIT 1');
$m -> query('UPDATE gracze SET poziom = poziom + 1 WHERE id = '.$_SESSION['id'].' LIMIT 1');
}
}