使用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 xfocus防注入资料
Apr 27 PHP
浅析php中常量,变量的作用域和生存周期
Aug 10 PHP
php页面防重复提交方法总结
Nov 25 PHP
php支付宝手机网页支付类实例
Mar 04 PHP
学习php设计模式 php实现策略模式(strategy)
Dec 07 PHP
基于thinkPHP类的插入数据库操作功能示例
Jan 06 PHP
IIS 7.5 asp Session超时时间设置方法
Apr 17 PHP
PHP编程求最大公约数与最小公倍数的方法示例
May 29 PHP
kindeditor 加入七牛云上传的实例讲解
Nov 12 PHP
PHP命令空间namespace及use的用法小结
Nov 27 PHP
PHP面向对象程序设计__tostring()和__invoke()用法分析
Jun 12 PHP
php与阿里云短信接口接入操作案例分析
May 27 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
初识Laravel
2014/10/30 PHP
php文件上传的两种实现方法
2016/04/04 PHP
js 代码集(学习js的朋友可以看下)
2009/07/22 Javascript
javascript 在网页中的运用(asp.net)
2009/11/23 Javascript
Jquery + Ajax调用webService实例代码(asp.net)
2010/08/27 Javascript
jQuery实现的Div窗口震动特效
2014/06/09 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
js实现字符串转日期格式的方法
2015/05/20 Javascript
Javascript实现通过选择周数显示开始日和结束日的实现代码
2016/05/30 Javascript
ES6新特性二:Iterator(遍历器)和for-of循环详解
2017/04/20 Javascript
Angular2使用Guard和Resolve进行验证和权限控制
2017/04/24 Javascript
史上最全JavaScript数组去重的十种方法(推荐)
2017/08/17 Javascript
vue.js 实现输入框动态添加功能
2018/06/25 Javascript
jQuery UI实现动画效果代码分享
2018/08/19 jQuery
ndm:NPM的桌面GUI应用程序
2018/10/15 Javascript
小程序实现留言板
2018/11/02 Javascript
vue element-ui读取pdf文件的方法
2019/11/26 Javascript
JavaScript实现简易计算器小功能
2020/10/22 Javascript
在Python上基于Markov链生成伪随机文本的教程
2015/04/17 Python
从零开始学Python第八周:详解网络编程基础(socket)
2016/12/14 Python
基于树莓派的语音对话机器人
2019/06/17 Python
Python将文字转成语音并读出来的实例详解
2019/07/15 Python
关于TensorFlow新旧版本函数接口变化详解
2020/02/10 Python
python代码实现TSNE降维数据可视化教程
2020/02/28 Python
大学教师年终总结的自我评价
2013/10/29 职场文书
求职推荐信范文
2013/12/01 职场文书
测控技术与仪器个人求职信范文
2013/12/30 职场文书
英语专业学生个人求职信
2014/01/28 职场文书
《绿色蝈蝈》教学反思
2014/03/02 职场文书
优秀团队申报材料
2014/12/26 职场文书
工程项目经理岗位职责
2015/02/02 职场文书
2015年宣传部工作总结范文
2015/03/31 职场文书
个人欠条范本
2015/07/03 职场文书
反邪教教育心得体会
2016/01/15 职场文书
《自然之道》读后感3篇
2019/12/17 职场文书
Spring Boot 启动、停止、重启、状态脚本
2021/06/26 Java/Android