在ID之后对Foreach循环进行排序

时间:2013-08-11 00:33:43

标签: php mysql

是否可以在ID之后对foreach循环的结果进行排序?首先使用最高ID等等...因为它是文章我想要最高ID(最新)是第一个:)

我的代码:

include_once('includes/connection.php');
include_once('includes/article.php');

$article = new Article;
$articles = $article->fetch_all();



?>
<html>
    <head>
        <title>CMS</title>
        <link rel="stylesheet" href="assets/style.css" />
    </head>

    <body>
        <div class="container">
            <a href="index.php" id="logo">CMS</a>

            <ol>
                <?php foreach ($articles as $article) { ?>
                    <li>
                        <a href="article.php?id=<?php echo $article['article_id']; ?>">
                            <?php echo $article['article_title']; ?>
                        </a>

                        - <small>
                            Posted <?php echo date('l jS', $article['article_timestamp']); ?>
                        </small>
                    </li>
                <?php } ?>
            </ol>

            <br />

            <small><a href="admin">Admin Login</a></small>

        </div>
    </body>
</html>

1 个答案:

答案 0 :(得分:2)

您正在寻找根据$articles字段对数组article_id进行排序 - 这可以使用函数usort来完成。

示例:

<?php
function cmp($a, $b)
{
    if ($a['article_id'] == $b['article_id']) {
        return 0;
    }
    return ($a['article_id'] < $b['article_id']) ? -1 : 1;
}


usort($articles, "cmp");

foreach ($articles as $article) {
    echo "$article: ". $article['article_id']." \n";
}