|
JLI Spieleprogrammierung
|
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen |
Autor |
Nachricht |
abc_d JLI Master Trainee
Alter: 34 Anmeldedatum: 27.01.2003 Beiträge: 615
Medaillen: Keine
|
Verfasst am: 24.01.2004, 13:27 Titel: Fehler beim erhöhen eines Wertes-Mysql |
|
|
Hi,
ich habe ein Problem mit Mysql. Folgender Code schreibt Daten in 2 Tabellen, einmal erhöht es den Tagewert, und einmal schreibt es einen Eintrag in eine Tabelle, die, die letzten 250 User inc. Ip und Referer speichert. Doch komischerweise ist die Anzahl der Einträge in der Tabelle mit den Informationen größer als die Zahl der User/pro tag in der onlineuser_day-tabelle.
Ich vermute das 2 verschiedene User gleichzeitig erhalten das der aktuelle Wert 200 User ist, und es beide auf 201 setzten, wäre das möglich?
Code: |
$if_ip_exist=mysql_query("SELECT IP,Time FROM onlineuser WHERE IP='$ip'",$link);
if(mysql_num_rows($if_ip_exist))
mysql_query("UPDATE onlineuser SET Time='$current_time' WHERE ip='$ip'",$link);
else
{
mysql_query("INSERT INTO onlineuser (ip, time, Referrer) VALUES('$ip', '$current_time', '$url')");
$day=date("Y-m-d",$current_time);
$Referer = str_replace("http://", "", $url);
$Referer = ereg_replace("/(.*)", "", $Referer);
mysql_query("LOCK TABLES onlineuser_day WRITE,onlineuser_day READ",$link);
if(mysql_num_rows(mysql_query("SELECT User FROM onlineuser_day WHERE Date='$day'",$link)))
{
mysql_query("UPDATE onlineuser_day SET User=User+1 WHERE Date='$day'",$link);
}
else
{
mysql_query("INSERT INTO onlineuser_day (User, Date) VALUES('1', '$day')",$link);
}
}
|
Woran liegt das? _________________ http://mitglied.lycos.de/sarti/linuxisevil.gif Linux is evil - get the fact.
Never touch a running System - der Systemling |
|
Nach oben |
|
|
AFE-GmdG JLI MVP
Alter: 45 Anmeldedatum: 19.07.2002 Beiträge: 1374 Wohnort: Irgendwo im Universum... Medaillen: Keine
|
Verfasst am: 25.01.2004, 20:55 Titel: |
|
|
Wäre prinzipiell möglich, ist bei normaler Webseitenbenutzung jedoch praktisch ausgeschlossen (es müsste ein Prezesskontextwechsel während der abarbeitung des PHP-Skriptes stattfinden, wozu der Webserver ebenfalls 2 Anfragen quasiparallel bearbeiten müsste - wie gesagt, sehr unwahrscheinlich bei normaler Webseitenauslastung.
Also ist der Fehler eventuell woanders zu suchen. Weitere Fehlerquellen: Sessionverwaltung mit veralterten Daten, die für Berechnungen herangezogen werden.
AFE-GmdG _________________
CPP: | float o=0.075,h=1.5,T,r,O,l,I;int _,L=80,s=3200;main(){for(;s%L||
(h-=o,T= -2),s;4 -(r=O*O)<(l=I*I)|++ _==L&&write(1,(--s%L?_<(L)?--_
%6:6:7)+\"World! \\n\",1)&&(O=I=l=_=r=0,T+=o /2))O=I*2*O+h,I=l+T-r;} |
|
|
Nach oben |
|
|
|
|
Du kannst keine Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum nicht antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen.
|
Powered by phpBB © 2001, 2005 phpBB Group Deutsche Übersetzung von phpBB.de
|