sql >> Databasteknik >  >> RDS >> Mysql

Visa år endast en gång i arkivslingan

Jag tycker att det enklaste sättet är något i stil med följande:

$entries = array();
while ($row = mysql_fetch_assoc($sql)) {
  $entries[$row['get_year']][] = $row;
}

foreach($entries as $year => $months) {
  echo '<dl>';
  echo '<dt>Entries from &nbsp;'. $year . '</dt>';

  echo '<dd>';
  foreach($months as $month) {\
    $this_month = date( 'F', mktime(0, 0, 0, $row["get_month"]) );

    echo '<a href="archives.php?month='. $month['get_month'] .'">Entries from &nbsp;'. $this_month . '&nbsp;</a>(' . $month['entries'] . ')';
  }
  echo '</dd></dl>';


}

Den HTML-uppmärkningen är inte idealisk, men du borde förstå idén.



  1. Word wrap låter inte siffrorna lindas också

  2. Olika sätt att övervaka SQL Server AlwaysOn-tillgänglighetsgrupper

  3. Hur fyller man i ListView med db i tillgångsmappen?

  4. Vänster gå med med en distinkt fråga i Laravel