php mysql 双条件排序,PHP 类 MySQL 多字段排序 - array_multisort

f7ffb9dc35bd61ec28f23eccf97fc326.png

场景: 需在 PHP 内存中,多字段排序,类比 MySQL 中的 order by column1 desc, column2 asc

题目: 数据表中存在学生表,有年纪、分数两个字段,从数据库取出数据后,请在 PHP 内存中按年纪倒叙,分数正序排列

解答: 用 array_multisort 实现$arrayFetchFromMysql = [

[

'id' => 1,

'age' => 16,

'score' => 86,

],

[

'id' => 2,

'age' => 18,

'score' => 95,

],

[

'id' => 3,

'age' => 25,

'score' => 60,

]

];

array_multisort(

array_column($arrayFetchFromMysql, 'age'), SORT_DESC,

array_column($arrayFetchFromMysql, 'score'), SORT_ASC,

$arrayFetchFromMysql

);

exit(json_encode($arrayFetchFromMysql));

打印结果[

{

"id": 3,

"age": 25,

"score": 60

},

{

"id": 2,

"age": 18,

"score": 95

},

{

"id": 1,

"age": 16,

"score": 86

}

]

解析

该操作需配合 array_coumn 函数,以上题目是两个字段排序,对更多字段排序也可以复用以上套路。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP 中,可以使用 `array_multisort()` 或 `usort()` 函数来对二维数组进行排序。 `array_multisort()` 函数可以同时对多个数组或多维数组进行排序,并且可以指定升序或降序。以下是一个随机排序的示例: ```php // 定义二维数组 $people = array( array('name' => 'Tom', 'age' => 20), array('name' => 'John', 'age' => 25), array('name' => 'Mary', 'age' => 18), array('name' => 'Peter', 'age' => 30) ); // 获取年龄列作为排序依据 foreach ($people as $key => $row) { $age[$key] = $row['age']; } // 使用 $age 数组对 $people 数组进行排序 array_multisort($age, SORT_DESC, $people); // 输出排序结果 print_r($people); ``` 上述示例中,我们首先使用 `foreach` 循环遍历 `$people` 数组,获取其中的年龄列作为排序依据,并将其存储到 `$age` 数组中。然后,使用 `array_multisort()` 函数对 `$people` 数组进行排序排序规则为按照年龄列降序排列。最后,输出排序后的结果。 另外,也可以使用 `usort()` 函数对二维数组进行排序,该函数需要自定义排序函数。以下是一个随机排序的示例: ```php // 定义二维数组 $people = array( array('name' => 'Tom', 'age' => 20), array('name' => 'John', 'age' => 25), array('name' => 'Mary', 'age' => 18), array('name' => 'Peter', 'age' => 30) ); // 自定义随机排序函数 function randomSort($a, $b) { return rand(-1, 1); } // 使用 usort() 函数对 $people 数组进行排序 usort($people, 'randomSort'); // 输出排序结果 print_r($people); ``` 上述示例中,我们首先定义了一个自定义的排序函数 `randomSort()`,该函数返回 -1、0 或 1 中的一个随机值。然后,使用 `usort()` 函数对 `$people` 数组进行排序排序规则为按照 `randomSort()` 函数的返回值进行排序。最后,输出排序后的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值