举个案例吧,要求显示最新注册的10个 用户,最新注册的显示在最下面。
现在数据库查询按照得到的data数据如下:
$data = array(
array(
'name' => '李四',
'create_time' => '1592848229',//2020/6/23 1:50:29
),
array(
'name' => '张三',
'create_time' => '1592847826',//2020/6/23 1:43:46
),
array(
'name' => '王五',
'create_time' => '1592848749',//2020/6/23 1:59:9
)
);
显然按照注册时间我们需要的结果顺序应该是 张三、李四、王五, 所以我们可以这么做:
<?php
$data = array(
array(
'name' => '李四',
'create_time' => '1592848229',//2020/6/23 1:50:29
),
array(
'name' => '张三',
'create_time' => '1592847826',//2020/6/23 1:43:46
),
array(
'name' => '王五',
'create_time' => '1592848749',//2020/6/23 1:59:9
)
);
//根据字段create_time对数组$data进行升序排列
//*****************方法一
$create_times = array_column($data,'create_time');
array_multisort($create_times,SORT_ASC,$data);
echo('<pre>');
var_dump($data);
echo('<hr>');
//【测试的时候发现array_column有的时候不好用,可以用方法二】
//*****************方法二
$flag = array();
foreach ($data as $value) {
$flag[] = $v['create_time'];
}
array_multisort($flag,SORT_ASC,$data);
var_dump($data);
?>
执行结果如下:
array(3) {
[0]=>
array(2) {
["name"]=>
string(6) "张三"
["create_time"]=>
string(10) "1592847826"
}
[1]=>
array(2) {
["name"]=>
string(6) "李四"
["create_time"]=>
string(10) "1592848229"
}
[2]=>
array(2) {
["name"]=>
string(6) "王五"
["create_time"]=>
string(10) "1592848749"
}
}
以下是函数详解:
一、array_column
1)、定义
array_column() 返回输入数组中某个单一列的值。
2)、语法
array_column(array,column_key,index_key);
参数 | 描述 |
---|---|
array | 必需。规定要使用的多维数组(记录集)。 |
column_key | 必需。需要返回值的列。可以是索引数组的列的整数索引,或者是关联数组的列的字符串键值。该参数也可以是 NULL,此时将返回整个数组(配合 index_key 参数来重置数组键的时候,非常有用)。 |
index_key | 可选。用作返回数组的索引/键的列。 |
二、array_multisort
1)、定义
array_multisort() 函数返回排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。
注释:字符串键名将被保留,但是数字键名将被重新索引,从 0 开始,并以 1 递增。
注释:您可以在每个数组后设置排序顺序和排序类型参数。如果没有设置,每个数组参数会使用默认值。
2)、语法
array_multisort(array1,sorting order,sorting type,array2,array3...)
参数 | 描述 |
---|---|
array1 | 必需。规定数组。 |
sorting order | 可选。规定排列顺序。可能的值:SORT_ASC - 默认。按升序排列 (A-Z)。SORT_DESC - 按降序排列 (Z-A)。 |
sorting type | 可选。规定排序类型。可能的值:SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。SORT_NUMERIC - 把每一项作为数字来处理。SORT_STRING - 把每一项作为字符串来处理。SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 setlocale() 进行更改)。SORT_NATURAL - 把每一项作为字符串来处理,使用类似 natsort() 的自然排序。SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。 |
array2 | 可选。规定数组。 |
array3 | 可选。规定数组。 |