Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Erweitertes Nachrichtenarchiv Jahre/Monat mit PHP MySql

Sie können GROUP BY nicht verwenden, wenn Sie auch die Namen der einzelnen Artikel haben möchten. Rufen Sie einfach die gesamte Liste ab und gruppieren Sie sie dann in einem Array nach Jahr und Monat.

$sql = "SELECT timestamp, your_id_column, your_title_column FROM `NEWS` ORDER BY timestamp DESC";

$newsdata = DataAccess::ArrayFetch($sql);

$nav = array();

foreach ( $newsdata as $news ) {
    $year = date('Y', $news['timestamp']);
    $month = date('F', $news['timestamp']);
    $nav[$year][$month][$news['your_id_column']] = $news['your_title_column'];
}

Wenn Sie das resultierende Array iterieren, können Sie die Nachrichten für jedes Jahr/jeden Monat zählen, um die Gesamtzahl zu ermitteln.

<ul>
    <?php
    foreach ( $nav as $k => $v ) {
        ?>
        <li><?php echo $k ?>
            <ul>
            <?php
            foreach ( $v as $k2 => $v2 ) {
                ?>
                <li><?php echo $k2.' ('.sizeof($v2).')' ?>
                    <ul>
                        <?php
                        foreach ( $v2 as $k3 => $v3 ) {
                            ?>
                            <li><?php echo $v3 ?></li>
                            <?php   
                        }
                        ?>
                    </ul>
                </li>
                <?php
            }
            ?>
            </ul>
        </li>
        <?php
    }
    ?>
</ul>