datum vergleiche/überlagerung mittels php/mysql

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

  • datum vergleiche/überlagerung mittels php/mysql

    hallo liebes forum..

    folgende (vereinfachte) mysql-tabelle liegt vor - die datumsangaben sind in diesem bild der einfachheit halber gekürzt und stehen in wirklichkeit als timestamp drinnen


    problem ist nun, wie bringe ich php bei, dass sich die daten überlagern können und er - wenn eine überlagerung der fall ist - das neueste "crdate" ausgeben soll..

    also aus der obigen tabelle soll dann folgendes ausgegeben werden:
    120-124: 5
    125-126: 7
    127-129: 3
    130-140: 5

    mein ansatz ist am ende als php-snippet eingefügt.. dieser erkennt schonmal dass der erste datensatz von einem zweiten überlagert wird.. aber es können ja beliebig viele überlagerungen auftreten.. und er muss dann immer wieder dynamisch auf die alten datensätze zurückgreifen können..

    hat jemand einen lösungsansatz?
    lieben gruß
    david


    PHP-Code:
    $aktYear date("Y");
    $leaveOld 0;


    for(
    $month 1$month<= 12$month++)
      {
        
    $timestamp mktime(0,0,0,$month,1,$aktYear);
        
    $dayPerMonth date("t"$timestamp);

        for(
    $day 1$day <= $dayPerMonth$day++)
          {
            
    $sqltmstmp mktime(0,0,0,$month,$day,$aktYear);


            unset(
    $arrAvail);
            
    $query "SELECT *
                        FROM tbl_avail
                       WHERE start = "
    .$sqltmstmp."
                    ORDER BY crdate DESC"
    ;
            
    $res mysql(TYPO3_db,$query);
            while(
    $row mysql_fetch_assoc($res))
              {
                
    $arrAvail $row;
              }
            
            
            if(
    $leaveOld == 0)
              {
                if(
    $arrAvail["avail"])
                  {
                    
    $availOut "<b>".$arrAvail["avail"]."</b>";
                    
    $crdate1 $arrAvail["crdate"];
                    
    $leaveOld $arrAvail["end"] - $arrAvail["start"];
                    
    $leaveOld round(($leaveOld 86400),0);
                  }
                else
                    
    $availOut "nothing set";
              }
            else
              {
                if(
    $arrAvail["crdate"] > $crdate1)
                    
    $availOut "<b>".$arrAvail["avail"]."</b>";
                else
                    
    $availOut $availOut;
                
    $leaveOld --;
              }


            echo 
    $day."-".$availOut;
          }
      } 

  • #2
    MAX() und MIN() in Verbindung mit GROUP BY.

    Warum verwendest du übrigens nicht einfach das DATETIME Format von MySQL und ersparst dir die Herumrechnerei mit den Timestamps?

    Kommentar


    • #3
      timestamps wegen typo3 - das ist da anscheinend vorgegeben..

      du würdest es also über mysql probieren?

      Kommentar


      • #4
        Ich würde generell mal Datenbankzugriffe und Ausgabe trennen.

        Erstmal alle benötigten Einträge in ein Array nach Datum sortiert einlesen (und nicht ein Query 365mal pro Jahr durchlaufen lassen, was unnötig Performance kostet).

        Und dann bau ich die Ausgabe mittels den Daten aus dem Array zusammen.

        Kommentar


        • #5
          klingt logisch.. da hast du wohl recht..
          bin zwar normalerweise kein neuling in sachen php und mysql - aber irgendwie steh ich grad ziemlich auf der leitung

          danke trotzdem für die hilfe

          Kommentar

          Lädt...
          X