JLI Spieleprogrammierung Foren-Übersicht JLI Spieleprogrammierung

 
 FAQFAQ   SuchenSuchen   MitgliederlisteMitgliederliste   BenutzergruppenBenutzergruppen 
 medals.php?sid=ed7485b341396e6c2a7d1bc6a6ee0d0fMedaillen   RegistrierenRegistrieren   ProfilProfil   Einloggen, um private Nachrichten zu lesenEinloggen, um private Nachrichten zu lesen   LoginLogin 

Fehler beim erhöhen eines Wertes-Mysql

 
Neues Thema eröffnen   Neue Antwort erstellen    JLI Spieleprogrammierung Foren-Übersicht -> Entwicklung
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

BeitragVerfasst am: 24.01.2004, 13:27    Titel: Fehler beim erhöhen eines Wertes-Mysql Antworten mit Zitat

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
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden
AFE-GmdG
JLI MVP
JLI MVP


Alter: 45
Anmeldedatum: 19.07.2002
Beiträge: 1374
Wohnort: Irgendwo im Universum...
Medaillen: Keine

BeitragVerfasst am: 25.01.2004, 20:55    Titel: Antworten mit Zitat

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
Benutzer-Profile anzeigen Private Nachricht senden E-Mail senden Website dieses Benutzers besuchen
Beiträge der letzten Zeit anzeigen:   
Neues Thema eröffnen   Neue Antwort erstellen    JLI Spieleprogrammierung Foren-Übersicht -> Entwicklung Alle Zeiten sind GMT
Seite 1 von 1

 
Gehe zu:  
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

Impressum