使用array mutisort 实现按某字段对数据排序


Posted in PHP onJune 18, 2013

array_multisort 的用法
一、先看最简单的情况。有两个数组:
$arr1 = array(1,9,5);
$arr2 = array(6,2,4);
array_multisort($arr1,$arr2);
print_r($arr1); // 得到的顺序是1,5,9
print_r($arr2); // 得到的顺序是6,4,2
我估计两个数组的值自始至终都是对应着的:1对应6,9对应2,5对应4。

我们再加多一个数组看看会怎样:
$arr1 = array(1,9,5);
$arr2 = array(6,2,4);
$arr3 = array(3,7,8);
array_multisort($arr1,$arr2,$arr3);

查看结果,1自始至终都对应6对应3,其它项也是如此。这种对应关系就是手册中所谓的“排序时保留原有的键名关联”。
另外也可以把每个数组想像成数据库表的一列。而对应着的1,6,3为一数据行,9,2,7为另一数据行。。。
array_multisort会先按第一个数组(想像成列)排序,如果第一个数组(列)的值相同,则按第二个数组(列)排序。

具体可以用下面的程式来测试:
$arr1 = array(1,9,5,9);
$arr2 = array(6,2,4,1);
$arr3 = array(3,7,8,0);
array_multisort($arr1,$arr2,$arr3);
可以想像这里$arr3的结果是(3,8,0,7)。

二、接下来讲解array_multisort的参数。
这个函数的参数很灵活。最简单的情况是如上面所示的以1个或n个数组作为参数,需要注意的是每个数组的项数要一样,否则会warning导致排序失效。
像这样array_multisort($arr1,$arr2,$arr3); 默认是所有数组都是升序排列,如果想对$arr2降序,并当作字符串去比较,就要写成:
array_multisort($arr1, $arr2, SORT_DESC, SORT_STRING, $arr3);
每个array后面可以跟一个排序顺序标志或一个排序类型标志,或者两种标志同时出现。但是每种排序标志在每个数组后面只能出现一个。
详细如下:
排序顺序标志:

SORT_ASC - 按照上升顺序排序(默认)
SORT_DESC - 按照下降顺序排序

排序类型标志:
 
SORT_REGULAR - 将项目按照通常方法比较(默认)
SORT_NUMERIC - 将项目按照数值比较
SORT_STRING - 将项目按照字符串比较

实际作用:把数据从数据库中提取出来之后可能是一个数组,如果想按照那个字段来进行排列,就可以先把那个字段提取出了来,成为单独的一个数组,然后再使用array_multisort进行排序,以达到对原数据按某字段数据排序的目的,下面是个小例子,按成绩对小朋友们排序。

<?php
$a=array(array('name'=>'张三','score'=>60),

array('name'=>'李四','score'=>90),

array('name'=>'王二','score'=>80)

);

$score=array();

foreach($a as $k => $v){

$score[$k]=$v['score'];

}

array_multisort($score,$a);

var_dump($score);

var_dump($a);
?>

结果大家自己运行一下吧
PHP 相关文章推荐
php 动态添加记录
Mar 10 PHP
PHP中读写文件实现代码
Oct 20 PHP
深入php-fpm的两种进程管理模式详解
Jun 03 PHP
什么是PEAR?什么是PECL?PHP中两个容易混淆的概念解释
Jul 01 PHP
PHP中异常处理的一些方法整理
Jul 03 PHP
PHP结合jQuery实现找回密码
Jul 22 PHP
php pthreads多线程的安装与使用
Jan 19 PHP
php之可变变量的实例详解
Sep 12 PHP
thinkphp5实现无限级分类
Feb 18 PHP
php 自定义函数实现将数据 以excel 表格形式导出示例
Nov 13 PHP
用php实现分页效果的示例代码
Dec 10 PHP
解析laravel使用workerman用户交互、服务器交互
Apr 28 PHP
php多个字符串替换成同一个的解决方法
Jun 18 #PHP
基于PHP读取csv文件内容的详解
Jun 18 #PHP
解析CodeIgniter自定义配置文件
Jun 18 #PHP
Yii PHP Framework实用入门教程(详细介绍)
Jun 18 #PHP
深入array multisort排序原理的详解
Jun 18 #PHP
解析PHP工厂模式的好处
Jun 18 #PHP
PHP实现邮件群发的源码
Jun 18 #PHP
You might like
海贼王:最美的悬赏令!
2020/03/02 日漫
xtree.js 代码
2007/03/13 Javascript
js 居中漂浮广告
2010/03/21 Javascript
解决遍历时Array.indexOf产生的性能问题
2012/07/03 Javascript
javascript创建动态表单的方法
2015/07/25 Javascript
jQuery1.9.1源码分析系列(十六)ajax之ajax框架
2015/12/04 Javascript
JS正则表达式比较常见用法
2016/01/26 Javascript
Html中 IFrame的用法及注意点
2016/12/22 Javascript
vue 实现通过手机发送短信验证码注册功能
2018/04/19 Javascript
layui 给数据表格加序号的方法
2018/08/20 Javascript
详解如何用VUE写一个多用模态框组件模版
2018/09/27 Javascript
JS实现盒子跟着鼠标移动及键盘方向键控制盒子移动效果示例
2019/01/29 Javascript
nodejs微信开发之自动回复的实现
2019/03/17 NodeJs
vue组件中iview的modal组件爬坑问题之modal的显示与否应该是使用v-show
2019/04/12 Javascript
使用Vue.observable()进行状态管理的实例代码详解
2019/05/26 Javascript
Vue实现简易计算器
2020/02/25 Javascript
2020淘宝618理想生活列车自动领喵币js脚本的代码
2020/06/02 Javascript
vue-cli —— 如何局部修改Element样式
2020/10/22 Javascript
Python 不同对象比较大小示例探讨
2014/08/21 Python
Python内置数据结构与操作符的练习题集锦
2016/07/01 Python
Python黑帽编程 3.4 跨越VLAN详解
2016/09/28 Python
selenium+python 去除启动的黑色cmd窗口方法
2018/05/22 Python
python flask安装和命令详解
2019/04/02 Python
python实践项目之监控当前联网状态详情
2019/05/23 Python
Python 中pandas索引切片读取数据缺失数据处理问题
2019/10/09 Python
python 解决flask 图片在线浏览或者直接下载的问题
2020/01/09 Python
Keras实现DenseNet结构操作
2020/07/06 Python
瑞典首都斯德哥尔摩的多元奢侈时尚品牌:Acne Studios
2017/07/09 全球购物
澳大利亚UGG工厂直销:Australian Ugg Boots
2017/10/14 全球购物
Trench London官方网站:高级风衣和意大利皮夹克
2020/07/11 全球购物
党员公开承诺事项
2014/03/25 职场文书
5.12护士节演讲稿
2014/04/30 职场文书
班级年度安全计划书
2014/05/01 职场文书
二人合伙经营协议书
2014/09/13 职场文书
python实现简单聊天功能
2021/07/07 Python
CSS3实现指纹特效代码
2022/03/17 HTML / CSS