Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP/MySQL]Błąd ze skryptem
Crop
post
Post #1





Grupa: Zarejestrowani
Postów: 31
Pomógł: 0
Dołączył: 5.04.2007

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


Stworzyłem kod który łączy się z serwerem OTS, sprawdza czy jest on on-line jeśli tak to dodaje do tabeli stats w polach test, online i points +1, a póżniej oblicza UpTime serwera, ale nie to jest problemem tylko to iż skrypt powinien się wykonywać tyle razy ile jest wpisów w tabeli, a niestety wykonuje się tylko raz...
Zamieszczam kod:

CODE

<?php
/*Skrypt aktualizacji stanu OTSów (Punkty, UpTime)*/
include "config.php";
include "modules/sec_connect/sec.php";
$query = mysql_query('select * from stats');
while($mysql = mysql_fetch_array($query)) {
$info = chr(6).chr(0).chr(255).chr(255).'info';
$sock = @fsockopen($mysql[ip], $mysql[port], $errno, $errstr, 1);
$test = $mysql[test] + 1;
if ($sock) {
fwrite($sock, $info);
$data='';

$online = $mysql[online] + 1;
$points['stats'] = $mysql[points] + 1;
}
else {
$online = $mysql[online];
$points['stats'] = $mysql[points];
}
if ($online>200 && $test>200) {
$online = $online - 100;
$test = $test - 100;
}
else {
}
$uptime = $online / $test;
$uptime = $uptime * 100;

$query = mysql_query('select id,points from otserv where id=\''. $mysql[id] .'\'');
$mysql = mysql_fetch_array($query);
if ($points['stats'] >= 5) {
$points['stats'] = $points['stats'] - 5;
$points['otserv'] = $mysql[points] + 1;
}
else {
$points['otserv'] = $mysql[points];
}
$sql['otserv'] = 'UPDATE otserv SET uptime='. $uptime .',points='. $points['otserv'] .' WHERE id='. $mysql[id] .'';
mysql_query($sql['otserv']);
$sql['stats'] = 'UPDATE stats SET online='. $online .',test='. $test .',points='. $points['stats'] .' WHERE id='. $mysql[id] .'';
mysql_query($sql['stats']);
}
?>

Z góry dziękuje

Ten post edytował Crop 30.08.2007, 15:39:42


--------------------
Prosty CMS a raczej CMf (zabawa z php)
Go to the top of the page
+Quote Post
nospor
post
Post #2





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




w petli wykonujesz taki kod:
  1. <?php
  2. $query = mysql_query('select id,points from otserv where id=''. $mysql[id] .'''); 
  3. $mysql = mysql_fetch_array($query);
  4. ?>

Nadpisujesz tym samym $query, ktore jest źródlem glownej petli. Krotko mowiac: uzywaj innych nazw zmiennych czlowieku i popraw bbcode na wlaciwe smile.gif


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

"Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista
"Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer

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 Aktualny czas: 19.08.2025 - 17:00