使用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 相关文章推荐
使用NetBeans + Xdebug调试PHP程序的方法
Apr 12 PHP
关于访问控制的一首PHP面试题(对属性或方法的访问控制)
Sep 13 PHP
php实现文件编码批量转换
Mar 10 PHP
php调用C代码的实现方法
Mar 11 PHP
php实现的click captcha点击验证码类实例
Sep 23 PHP
Laravel5中contracts详解
Mar 02 PHP
YII Framework框架教程之安全方案详解
Mar 14 PHP
PHP文件与目录操作示例
Dec 24 PHP
Mac系统完美安装PHP7详细教程
Jun 06 PHP
PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
Jul 19 PHP
PHP基于IMAP收取邮件的方法示例
Aug 07 PHP
PHP基于session.upload_progress 实现文件上传进度显示功能详解
Aug 09 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
php 魔术方法使用说明
2009/10/20 PHP
php 文章采集正则代码
2009/12/28 PHP
PHP正确解析UTF-8字符串技巧应用
2012/11/07 PHP
php实现将Session写入数据库
2015/07/26 PHP
PHP实现活动人选抽奖功能
2017/04/19 PHP
PHP守护进程化在C和PHP环境下的实现
2017/11/21 PHP
Laravel框架使用Seeder实现自动填充数据功能
2018/06/13 PHP
屏蔽Flash右键信息的js代码
2010/01/17 Javascript
一个js的tab切换效果代码[代码分离]
2010/04/11 Javascript
jQuery '行 4954 错误: 不支持该属性或方法' 的问题解决方法
2011/01/19 Javascript
js对象的比较
2011/02/26 Javascript
javascript实现简单加载随机色方块
2015/12/25 Javascript
JavaScript学习笔记整理之引用类型
2016/01/22 Javascript
ionic由于使用了header和subheader导致被遮挡的问题的两种解决方法
2016/09/22 Javascript
微信小程序 input输入框详解及简单实例
2017/01/10 Javascript
javascript实现简易计算器
2017/02/01 Javascript
jQuery插件autocomplete使用详解
2017/02/04 Javascript
jQuery Validate 校验多个相同name的方法
2017/05/18 jQuery
vue router动态路由下让每个子路由都是独立组件的解决方案
2018/04/24 Javascript
浅谈Webpack4 Tree Shaking 终极优化指南
2019/11/18 Javascript
[33:23]VG vs Pain 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
详解Python设计模式编程中观察者模式与策略模式的运用
2016/03/02 Python
python递归查询菜单并转换成json实例
2017/03/27 Python
Python基础教程之浅拷贝和深拷贝实例详解
2017/07/15 Python
Python中pip更新和三方插件安装说明
2018/07/08 Python
python3中函数参数的四种简单用法
2018/07/09 Python
pandas求两个表格不相交的集合方法
2018/12/08 Python
pandas去重复行并分类汇总的实现方法
2019/01/29 Python
Python3之乱码\xe6\x97\xa0\xe6\xb3\x95处理方式
2020/05/11 Python
Python 如何批量更新已安装的库
2020/05/26 Python
python dir函数快速掌握用法技巧
2020/12/09 Python
python Autopep8实现按PEP8风格自动排版Python代码
2021/03/02 Python
中文专业毕业生自荐信
2013/10/28 职场文书
企业整改报告范文
2014/11/08 职场文书
2015年妇产科工作总结
2015/05/18 职场文书
Java 语言中Object 类和System 类详解
2021/07/07 Java/Android