0

我有一个看起来像这样的数组:

{ [0]=> array(4) { "20" ["date"]=> string(10) "2013-01-25" ["content"]=> string(3) "ref" }

和 [1]、[2]... 看起来一样。

我想知道如何订购我的数组,所以 [0] 是最新日期。更改为时间戳不是一种意见。有任何想法吗?

4

3 回答 3

1

您可以使用usort()并编写自己的比较函数(一个比较“对象” - 内部数组的函数)。

由于日期的编写方式可以进行简单的字符串比较,因此您可以执行以下操作:

<?php
function compare($arr1, $arr2) {
   $date1 = $arr1[0];
   $date2 = $arr2[0];
   if($date1 > $date2){
       $ans = 1;
   }
   else if($date2 > $date1){
       $ans = -1;
   }
   else{
       $ans = 0;
   }
   return $ans;
}

$arr = array(array("date"=>"2013-01-25", "content"=>"ref"), 
                array("date"=>"2013-02-25", "content"=>"ref2"), 
                array("date"=>"2013-03-25", "content"=>"ref3")
        );

usort($arr, "compare");
print_r($arr);

?>

输出:

Array
(
    [0] => Array
        (
            [date] => 2013-03-25
            [content] => ref3
        )

    [1] => Array
        (
            [date] => 2013-02-25
            [content] => ref2
        )

    [2] => Array
        (
            [date] => 2013-01-25
            [content] => ref
        )

)
于 2013-02-28T04:06:45.890 回答
1

在您的查询中使用 order by。

ORDER BY date
于 2013-02-28T03:56:41.693 回答
0

试试这个:这对多维数组进行排序

$sort = array();
foreach($your_array as $k=>$v) {
    $sort['date'][$k] = $v['date'];
}

array_multisort($sort['date'], SORT_DESC, $your_array);


echo "<pre>";
print_r($your_array);
于 2013-02-28T04:30:30.283 回答