Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [php/time] Problem z pobieraniem rekordów
oomaster
post 1.07.2007, 16:28:25
Post #1





Grupa: Zarejestrowani
Postów: 305
Pomógł: 3
Dołączył: 4.08.2006
Skąd: GDA

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


Witam

od 1,5 godziny nie mogę znaleść błędu w pobieraniu:
  1. <?
  2. $OnLineLimit=300;
  3.  
  4. $OnLineAsk = @mysql_query("SELECT * FROM tabela WHERE online > ".(time()-$OnlineLimit)." ORDER BY login") or die(mysql_error());
  5.  
  6. while ($OnLineBack = mysql_fetch_array($OnLineAsk)) {
  7. $login = $OnLineBack['login'];
  8.  
  9. echo "<b>$login...</b><br/>";
  10. }
  11. ?>


Połączenie z bazą mam według obliczeń użytkownik powinien być online, żadnego błędu nie wykrywa. Jedynym błędem może być zapytanie, chociaż nie widzę w nim błędu.

Czy może mi ktoś powiedzieć gdzie tu jest błąd.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 5)
phpion
post 1.07.2007, 16:35:58
Post #2





Grupa: Moderatorzy
Postów: 6 072
Pomógł: 861
Dołączył: 10.12.2003
Skąd: Dąbrowa Górnicza




Usuń @ sprzed mysql_query i zobacz co ci się pokaże.
Go to the top of the page
+Quote Post
Grzyw
post 1.07.2007, 16:39:30
Post #3





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

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


SQL query wygląda OK. A sprawdź poprzez klienta MySQL w bazie, czy dobrze zapisywane masz informacje w polu online. Bez użycia PHP. Wygląda mi to na błąd w aktualizowaniu tej tabeli, skoro zapytanie jest OK, a nie wyświetla poprawnych informacji.


--------------------
Idąc po czyichś śladach, nie zajdziesz ani kroku dalej...
Go to the top of the page
+Quote Post
kossa
post 1.07.2007, 16:46:59
Post #4





Grupa: Zarejestrowani
Postów: 1 165
Pomógł: 9
Dołączył: 9.04.2002
Skąd: Toruń

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


funkcja time() jest funkcją mysql więc powinna być w "zapytaniu" a nie jako z php dodawana bo php najpierw próbuje wywołać funkcję time() a ma to zrobić sql. Chyba że masz taką funkcję, to cofam co napisałem.

  1. <?php
  2. $OnLineAsk = @mysql_query("SELECT * FROM tabela WHERE online > (time()-".$OnlineLimit.") ORDER BY login") or die(mysql_error());
  3. ?>


Łukasz


--------------------
Go to the top of the page
+Quote Post
Grzyw
post 1.07.2007, 17:03:58
Post #5





Grupa: Zarejestrowani
Postów: 561
Pomógł: 75
Dołączył: 19.08.2004
Skąd: Wrocław

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


Funkcja time() istnieje w PHP i zwraca obecną wartość unix'owego znacznika czasu.

Ten post edytował Grzyw 1.07.2007, 17:04:14


--------------------
Idąc po czyichś śladach, nie zajdziesz ani kroku dalej...
Go to the top of the page
+Quote Post
oomaster
post 1.07.2007, 17:57:26
Post #6





Grupa: Zarejestrowani
Postów: 305
Pomógł: 3
Dołączył: 4.08.2006
Skąd: GDA

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


w phpMyAdmin ładnie wyświetliło rekord angrysmiley.gif
  1. SELECT * FROM moto2_user WHERE online > '.(time()-$OnlineLimit).'
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: 19.07.2025 - 16:56