PHP 二维数组根据某个字段排序的具体实现

从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条.

本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求。

要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条。

遇到这个要求的时候就不是 ORDER BY 能解决的问题了。因此翻看 PHP 手册查找到了如下方法,做此笔记。

废话少说,奉上代码,清单如下:

  1. <?php
  2. /**
  3. * 二维数组根据某个字段排序
  4. * 功能:按照用户的年龄倒序排序
  5. * @author ruxing.li
  6. */
  7. header('Content-Type:text/html;Charset=utf-8');
  8. $arrUsers = array(
  9. array(
  10. 'id' => 1,
  11. 'name' => '张三',
  12. 'age' => 25,
  13. ),
  14. array(
  15. 'id' => 2,
  16. 'name' => '李四',
  17. 'age' => 23,
  18. ),
  19. array(
  20. 'id' => 3,
  21. 'name' => '王五',
  22. 'age' => 40,
  23. ),
  24. array(
  25. 'id' => 4,
  26. 'name' => '赵六',
  27. 'age' => 31,
  28. ),
  29. array(
  30. 'id' => 5,
  31. 'name' => '黄七',
  32. 'age' => 20,
  33. ),
  34. );
  35. $sort = array(
  36. 'direction' => 'SORT_DESC', //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
  37. 'field' => 'age', //排序字段
  38. );
  39. $arrSort = array();
  40. foreach($arrUsers AS $uniqid => $row){
  41. foreach($row AS $key=>$value){
  42. $arrSort[$key][$uniqid] = $value;
  43. }
  44. }
  45. if($sort['direction']){
  46. array_multisort($arrSort[$sort['field']], constant($sort['direction']), $arrUsers);
  47. }
  48. var_dump($arrUsers);
  49. /*
  50. 输出结果:
  51. array (size=5)
  52. 0 =>
  53. array (size=3)
  54. 'id' => int 5
  55. 'name' => string '黄七' (length=6)
  56. 'age' => int 20
  57. 1 =>
  58. array (size=3)
  59. 'id' => int 2
  60. 'name' => string '李四' (length=6)
  61. 'age' => int 23
  62. 2 =>
  63. array (size=3)
  64. 'id' => int 1
  65. 'name' => string '张三' (length=6)
  66. 'age' => int 25
  67. 3 =>
  68. array (size=3)
  69. 'id' => int 4
  70. 'name' => string '赵六' (length=6)
  71. 'age' => int 31
  72. 4 =>
  73. array (size=3)
  74. 'id' => int 3
  75. 'name' => string '王五' (length=6)
  76. 'age' => int 40
  77. */