使用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的header和asp中的redirect比较
Oct 09 PHP
一个PHP操作Access类(PHP+ODBC+Access)
Jan 02 PHP
php url地址栏传中文乱码解决方法集合
Jun 25 PHP
用PHP实现Ftp用户的在线管理
Feb 16 PHP
ThinkPHP CURD方法之limit方法详解
Jun 18 PHP
PHP中防止SQL注入方法详解
Dec 25 PHP
CI框架中通过hook的方式实现简单的权限控制
Jan 07 PHP
php实现模拟登陆方正教务系统抓取课表
May 19 PHP
php实现多城市切换特效
Aug 09 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
Nov 17 PHP
PHP读取word文档的方法分析【基于COM组件】
Aug 01 PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
Jun 16 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 file_get_contents 函数超时的几种解决方法
2009/07/30 PHP
PHP优于Node.js的五大理由分享
2012/09/15 PHP
学习php设计模式 php实现合成模式(composite)
2015/12/08 PHP
PHP正则验证字符串是否为数字的两种方法并附常用正则
2019/02/27 PHP
YII框架http缓存操作示例
2019/04/29 PHP
怎么用javascript进行拖拽
2006/07/20 Javascript
JavaScript国旗变换效果代码
2008/08/13 Javascript
你的 mixin 真的兼容 ECMAScript 5 吗?
2013/04/11 Javascript
js 判断文件类型并控制表单提交示例代码
2013/11/14 Javascript
关于js内存泄露的一个好例子
2013/12/09 Javascript
jQuery+css3动画属性制作猎豹浏览器宽屏banner焦点图
2015/03/16 Javascript
JS实现黑色大气的二级导航菜单效果
2015/09/18 Javascript
详解JavaScript中Hash Map映射结构的实现
2016/05/21 Javascript
JS数组操作之增删改查的简单实现
2017/08/21 Javascript
JS实现table表格固定表头且表头随横向滚动而滚动
2017/10/26 Javascript
vue获取dom元素注意事项
2017/12/28 Javascript
vue-cli配置环境变量的方法
2018/07/09 Javascript
vue中使用axios post上传头像/图片并实时显示到页面的方法
2018/09/27 Javascript
原生js实现碰撞检测
2020/03/12 Javascript
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
在ubuntu16.04中将python3设置为默认的命令写法
2018/10/31 Python
python定时检测无响应进程并重启的实例代码
2019/04/22 Python
python TF-IDF算法实现文本关键词提取
2019/05/29 Python
django框架ModelForm组件用法详解
2019/12/11 Python
python闭包、深浅拷贝、垃圾回收、with语句知识点汇总
2020/03/11 Python
如何在django中实现分页功能
2020/04/22 Python
python 实现围棋游戏(纯tkinter gui)
2020/11/13 Python
HTML5本地数据库基础操作详解
2016/04/26 HTML / CSS
世界各地的旅游、观光和活动:Isango!
2019/10/29 全球购物
如何现实servlet的单线程模式
2014/08/05 面试题
幼儿园教育教学反思
2014/01/31 职场文书
年检委托书
2014/08/30 职场文书
党的群众路线教育实践活动领导班子整改措施
2014/09/30 职场文书
机关党员四风问题个人整改措施
2014/10/26 职场文书
mysql主从复制的实现步骤
2021/10/24 MySQL
Java tomcat手动配置servlet详解
2021/11/27 Java/Android