使用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 相关文章推荐
如何使用脚本模仿登陆过程
Nov 22 PHP
PHP5中虚函数的实现方法分享
Apr 20 PHP
php高级编程-函数-郑阿奇
Jul 04 PHP
php中检查文件或目录是否存在的代码小结
Oct 22 PHP
深入PHP autoload机制的详解
Jun 09 PHP
php获取发送给用户的header信息的方法
Mar 16 PHP
PHP中把数据库查询结果输出为json格式简单实例
Apr 09 PHP
PHP将Excel导入数据库及数据库数据导出至Excel的方法
Jun 24 PHP
php通过淘宝API查询IP地址归属等信息
Dec 25 PHP
Laravel中日期时间处理包Carbon的简单使用
Sep 21 PHP
php 将json格式数据转换成数组的方法
Aug 21 PHP
thinkphp框架表单数组实现图片批量上传功能示例
Apr 04 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分页示例代码
2007/03/19 PHP
PHP jQuery表单,带验证具体实现方法
2014/02/15 PHP
php冒泡排序、快速排序、快速查找、二维数组去重实例分享
2014/04/24 PHP
PHPAnalysis中文分词类详解
2014/06/13 PHP
PHP多维数组转一维数组的简单实现方法
2015/12/23 PHP
PHP如何使用Memcached
2016/04/05 PHP
PHP实现数据四舍五入的方法小结【4种方法】
2019/03/27 PHP
php 下 html5 XHR2 + FormData + File API 上传文件操作实例分析
2020/02/28 PHP
IE6下通过a标签点击切换图片的问题
2010/11/14 Javascript
jquery cookie实现的简单换肤功能适合小网站
2013/08/25 Javascript
javascript实现促销倒计时+fixed固定在底部
2013/09/18 Javascript
直接在JS里创建JSON数据然后遍历使用
2014/07/25 Javascript
基于jQuery Bar Indicator 插件实现进度条展示效果
2015/09/30 Javascript
使用BootStrapValidator完成前端输入验证
2016/09/28 Javascript
jQuery扩展实现text提示还能输入多少字节的方法
2016/11/28 Javascript
Vue-resource实现ajax请求和跨域请求示例
2017/02/23 Javascript
解决JQuery全选/反选第二次失效的问题
2017/10/11 jQuery
vue checkbox 全选 数据的绑定及获取和计算方法
2018/02/09 Javascript
JavaScript实现点击出现图片并统计点击次数功能示例
2018/07/23 Javascript
微信小程序的授权实现过程解析
2019/08/02 Javascript
vue-cli2与vue-cli3在一台电脑共存的实现方法
2019/09/25 Javascript
浅谈Vue中render中的h箭头函数
2019/11/07 Javascript
[01:43]倾听DOTA2英雄之声 魅惑魔女国服配音鉴赏
2013/06/06 DOTA
Python实现批量读取图片并存入mongodb数据库的方法示例
2018/04/02 Python
使用python存储网页上的图片实例
2018/05/22 Python
解决Python内层for循环如何break出外层的循环的问题
2019/06/24 Python
python KNN算法实现鸢尾花数据集分类
2019/10/24 Python
Python开发企业微信机器人每天定时发消息实例
2020/03/17 Python
django项目中新增app的2种实现方法
2020/04/01 Python
基于python3.7利用Motor来异步读写Mongodb提高效率(推荐)
2020/04/29 Python
厨师岗位职责
2013/11/12 职场文书
对外汉语专业大学生职业生涯规划范文
2014/09/13 职场文书
升学宴答谢词
2015/01/05 职场文书
家属慰问信
2015/02/14 职场文书
降价通知函
2015/04/23 职场文书
发票退票证明
2015/06/24 职场文书