一、一维数组排序
- sort() - 以升序对数组排序
- rsort() - 以降序对数组排序
- asort() - 根据值,以升序对关联数组进行排序
- ksort() - 根据键,以升序对关联数组进行排序
- arsort() - 根据值,以降序对关联数组进行排序
- krsort() - 根据键,以降序对关联数组进行排序
二、二维数组排序
1、单个字段排序:
$data = [
['id' => 1, 'name' => '李大', 'sort' => 8],
['id' => 2, 'name' => '李二', 'sort' => 4],
['id' => 3, 'name' => '李三', 'sort' => 6],
];
// 先取出要排序的字段的值
$sort = array_column($data, 'sort');
// 按照sort字段升序 其中SORT_ASC表示升序 SORT_DESC表示降序
array_multisort($sort, SORT_ASC, $data);
// 输出结果
var_dump($data);
array(3) {
[0] => array(3) {
["id"] => int(2)
["name"] => string(6) "李二"
["sort"] => int(4)
}
[1] => array(3) {
["id"] => int(3)
["name"] => string(6) "李三"
["sort"] => int(6)
}
[2] => array(3) {
["id"] => int(1)
["name"] => string(6) "李大"
["sort"] => int(8)
}
}
2、多个字段排序:
$data = [
['id' => 1, 'name' => '李大', 'sort' => 6],
['id' => 2, 'name' => '李二', 'sort' => 4],
['id' => 3, 'name' => '李三', 'sort' => 8],
];
// 先取出要排序的字段的值
$sort = array_column($data, 'sort');
$name = array_column($data, 'name');
// 先按照sort字段升序,再按照name字段降序
array_multisort($sort, SORT_ASC, $name, SORT_DESC, $data);
// 输出结果
var_dump($data);
array(3) {
[0] => array(3) {
["id"] => int(2)
["name"] => string(6) "李二"
["sort"] => int(4)
}
[1] => array(3) {
["id"] => int(1)
["name"] => string(6) "李大"
["sort"] => int(6)
}
[2] => array(3) {
["id"] => int(3)
["name"] => string(6) "李三"
["sort"] => int(8)
}
}