PHP函数之array_multisort()

PHP函数之array_multisort()


array_multisort()

说明:

array_multisort() 函数返回排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序,可以理解为mysql中的sort key asc, key2 desc

语法

array_multisort(array1,sorting order,sorting type,array2,array3...)

参数

参数 描述
array1 必需。规定数组。
sorting order 可选。规定排列顺序。可能的值:SORT_ASC - 默认。按升序排列 (A-Z)。SORT_DESC - 按降序排列 (Z-A)。
sorting type 可选。规定排序类型。
array2 可选。规定数组。
array3 可选。规定数组。

sorting type 可选的值:

  • SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。

  • SORT_NUMERIC - 把每一项作为数字来处理。

  • SORT_STRING - 把每一项作为字符串来处理。

  • SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 setlocale() 进行更改)。

  • SORT_NATURAL - 把每一项作为字符串来处理,使用类似 natsort() 的自然排序。

  • SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。

示例

  1. 一维多个数组排序

结果

Array
(
    [0] => Cat
    [1] => Dog
    [2] => Dog
)
Array
(
    [0] => Missy
    [1] => Fido    //dog相同时,fido排序在pluto的前面
    [2] => Pluto
)
  1. 多维数组排序

 array(
        'num1' => 3,
        'num2' => 27 
    ),
    
    '1' => array(
        'num1' => 5,
        'num2' => 50
    ),
    
    '2' => array(
        'num1' => 4,
        'num2' => 44
    ),
    
    '3' => array(
        'num1' => 3,
        'num2' => 78
    ) 
);

foreach ( $arr as $key => $row ){
    $num1[$key] = $row ['num1'];
    $num2[$key] = $row ['num2'];
}

array_multisort($num1, SORT_ASC, $num2, SORT_DESC, $arr);

print_r($arr);

结果

Array
(
    [0] => Array
        (
            [num1] => 3
            [num2] => 78
        )

    [1] => Array
        (
            [num1] => 3
            [num2] => 27
        )

    [2] => Array
        (
            [num1] => 4
            [num2] => 44
        )

    [3] => Array
        (
            [num1] => 5
            [num2] => 50
        )

)

你可能感兴趣的:(php,数据库)