probleme mit date() und timestamp

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • probleme mit date() und timestamp

    hallo.
    ich versuche momentan ein eigenes forum zu proggen und hab nun folgendes problem:
    ich möchte aus einer db(users) die lastactivity auslesen(als timestamp gespeichert) und möchte es so anzeigen lassen, wie phpmyadmin das auch macht(yyyy-mm-dd hh:mm:ss)
    aber wenn ich folgendes versuche:
    PHP-Code:
    #sqlanweisung
    <?=date("Y-m-d H:i:s",$userlastactivity); ?>
    kommt dieser fehler mit einer ausgabe(steht unten drin):

    Notice: A non well formed numeric value encountered in /usr/export/www/hosting/funwars/acp/userlist.php on line 42
    1970-01-01 01:33:28


    was hab ich dabei falsach gemacht? kann mir bitte jemand helfen? ich brauch diese funktion und datetime kann ich nicht nehmen
    Zuletzt geändert von Champ Wasili; 20.11.2008, 17:43.

  • #2
    Hallo,

    was gibt
    PHP-Code:
    echo $userlastactivity
    aus?


    vg
    gourmet

    Kommentar


    • #3
      ach so. das wird direkt bei der abfrage umgewandelt? oder ist der wert timestamp für ein feld nicht gleichzeitig ein unix timestamP?

      weil das gibt jetzt sofort das richtige aus. wie errechnet man denn dabei eine halbe std? 00:30:00 oder 1800? was stimmt?

      Kommentar


      • #4
        du hast die Zeit in deiner Datenbank als mysql Timestamp?

        wie übergibst du die Zeit, wenn du sie einträgst, mit now() oder time()?

        http://dev.mysql.com/doc/refman/5.1/de/datetime.html
        http://dev.mysql.com/doc/refman/5.0/...functions.html
        Zuletzt geändert von gourmet; 20.11.2008, 18:12.

        Kommentar


        • #5
          ich nutze beim eintragen NOW() und möchte nun bei allen datensätze bei denen dieser wert >30min ist, bei online NULL schreiben wie muss ich da die 30 min schreben?

          Kommentar


          • #6
            siehe links die in meinem vorherigen Post stehen, da sind die Funktionen die du dafür benötigst.

            Kommentar


            • #7
              die links hast du aber reineditiert da war ich schon am tippen für meinen beitrag! außerdem verstehe ich das nicht richtig. ist jetztdiese anweisung richtig>?

              PHP-Code:
              $sqli='UPDATE `users` SET `UserSession` = NULL WHERE lastactivity > (NOW() - \'0000-00-00 00:30:00\')'
              Oder was anderes?
              ich verstehe die links oben nicht richtig. bei dem einen steht, das auf timstamp eingegangen wird, aber dann kommt nichts darüber. oder ich hab das überlesen. un den anderen verstehe ich komplett nicht!

              Kommentar


              • #8
                http://dev.mysql.com/doc/refman/5.0/...ction_date-add

                Kommentar


                • #9
                  ich hab doch schon geschrieben, das ich den link nicht recht verstehe. mein englisch ist nicht das beste und ich wollte einfach nur wissen, ohb der obige code richtig ist, oder, wenn nicht, mir jemand bei der erstellung des richtigen codes hefen kann!

                  Kommentar


                  • #10
                    Ist das nicht ein ganz normaler Syntaxfehler, weil da einfach nur
                    =date();
                    steht?
                    Ich würde mal das "=" davor entfernen oder eine Variable davor schreiben.

                    Oder hab ich mich jetzt völlig blamiert?

                    Kommentar


                    • #11
                      <?= ist eine kurzform für

                      <? echo

                      Aber das problem hatten wir eigentlih schon geköst. esgeht darum, dass ich alle datensätze ändern will, die älter als 30min sind!

                      Kommentar


                      • #12
                        PHP-Code:
                        $now time()
                        $then now 60 30

                        $sql 
                        "UPDATE table SET foo=NULL WHERE bar >".$then;
                        mysql_query($sql) || die(mysql_error()); 

                        Zum Beispiel:
                        PHP-Code:
                        //////////////////// IDLER von der Site kicken!
                        // OLT = OnLinteTotal
                        // LIT = last LogInTime
                        // LACT = LastActivity
                        //////////////////// 
                            
                        $now time();
                            
                        $idle $idles 60;
                            
                        $sql="SELECT UserSession, OLT, LIT, LACT
                            FROM site_users
                            WHERE UserSession!=''"
                        ;
                            
                        $result=mysql_query($sql) or die(mysql_error());
                              while (
                        $zeitrechn=mysql_fetch_assoc($result)) {
                              
                        $olt $zeitrechn['OLT'] + $now $zeitrechn['LIT'];
                              
                        $lact $zeitrechn['LACT'];
                              
                        $user $zeitrechn['UserSession'];
                              
                        $verst $now $lact;
                                if (
                        $verst $idle) {
                                 
                        $sql="UPDATE site_users
                                 SET
                                 UserSession=NULL,
                                 OLT='"
                        .$olt."'
                                 WHERE UserSession='"
                        .$user."'";
                                 
                        mysql_query($sql);
                                 
                        // echo 'debug';
                                
                        }
                              } 
                        Zuletzt geändert von nichtsooft; 21.11.2008, 20:09.
                        WHILE (!$asleep) { $sheep++; }

                        Kommentar


                        • #13
                          also... ich hab nen bisschen gegoogelt aber nur damit ich es jetzt verstanden hab...

                          mysql speichert einen Timestamp(sekunden seit 1970)...
                          aber gibt ihn formatiert mit datum und uhrzeit aus...
                          und zum ändern muss man einfach die sekunden addieren/subtahieren.


                          richtig? wenn ja vielen dank! wenn nein, sagt bitte bescheid was falsch ist!

                          Kommentar


                          • #14
                            nein, du hast doch geschrieben das du die Zeit mit now() übergibst und der LINK ist auf deutsch und den Text sollte man eigentlich verstehen.

                            http://dev.mysql.com/doc/refman/5.1/de/datetime.html

                            ungetestet...

                            PHP-Code:
                            $sqli='UPDATE `users` SET `UserSession` = NULL WHERE lastactivity >= DATE_SUB(NOW(), INTERVAL 30 MINUTE)'
                            hab noch mal ein wenig überlegt und habe den Code ein wenig verändert, vielleicht ists jetzt richtiger kann man selbst ja vielleicht auch mal gebrauchen

                            vg
                            gourmet
                            Zuletzt geändert von gourmet; 21.11.2008, 21:02.

                            Kommentar


                            • #15
                              Ja! Ein timestamp so wie er meistens verwendet wird ist reinter Integer dessen Wertigkeit vom Zeitpunkt 0 des Unixzeitalters bis zum aktuellen Zeitpunkt in Sekunden gemessen wird.

                              Der große Vorteil ist die deutlich umgänglichere Umgangsform bei den SQL-Queries bei denen oft die Operatoren >,<,=>,<= genutzt werden.
                              PHP-Code:
                              $prf1 "SELECT id FROM site_years WHERE
                                  start < "
                              .$_GET['b']." AND end > ".$_GET['b']."
                                      OR
                                  start > "
                              .$_GET['b']." AND end < ".$_GET['e']."
                                      OR
                                  start < "
                              .$_GET['b']." AND end > ".$_GET['e']."
                                      OR
                                  start < "
                              .$_GET['e']." AND end > ".$_GET['e']."
                                      LIMIT 1"

                              mit date() formatierst du den INT dann noch schön.
                              PHP-Code:
                              ///////////// Tag.Monat.Jahr - 01.01.1970
                              date("d.m.Y"$zeitpunkt
                              Zusätzlich kannst dir noch irgendwo Arrays mit Monatsnamen und Tagesbezeichnungen anlegen und mit getdate() weiteren Schabernak treiben! Z.B.:
                              PHP-Code:
                              //////////// Fun mit timestamps
                              $tagpub[] = 'So.';
                              $tagpub[] = 'Mo.';
                              $tagpub[] = 'Di.';
                              $tagpub[] = 'Mi.';
                              $tagpub[] = 'Do.';
                              $tagpub[] = 'Fr.';
                              $tagpub[] = 'Sa.';

                              $more getdate($zeitpunkt);
                              echo 
                              $tagpub[$more['wday']];
                              echo 
                              date("d.m.Y"$zeitpunkt); 

                              Lg. aus Wien
                              WHILE (!$asleep) { $sheep++; }

                              Kommentar

                              Lädt...
                              X