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
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;
}
}
Kommentar