使用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中的日期及时间
Nov 23 PHP
提高PHP编程效率 引入缓存机制提升性能
Feb 15 PHP
php 数组的指针操作实现代码
Feb 08 PHP
MySQL 日期时间函数常用总结
Jun 12 PHP
PHP获取栏目的所有子级和孙级栏目的ID号示例
Apr 01 PHP
Codeigniter操作数据库表的优化写法总结
Jun 12 PHP
ThinkPHP模板比较标签用法详解
Jun 30 PHP
mantis安装、配置和使用中的问题小结
Jul 14 PHP
php结合正则批量抓取网页中邮箱地址
May 19 PHP
PHP排序算法类实例
Jun 17 PHP
php实现的网页版剪刀石头布游戏示例
Nov 25 PHP
PHP laravel中的多对多关系实例详解
Jun 07 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 仿Comsenz安装效果代码打包提供下载
2010/05/09 PHP
PHP备份数据库生成SQL文件并下载的函数代码
2012/02/05 PHP
php中计算未知长度的字符串哪个字符出现的次数最多的代码
2012/08/14 PHP
PHP四大安全策略
2014/03/12 PHP
PHP实现适用于文件内容操作的分页类
2016/06/15 PHP
js CSS操作方法集合
2008/10/31 Javascript
前台js改变Session的值(用ajax实现)
2012/12/28 Javascript
Json字符串转换为JS对象的高效方法实例
2013/05/01 Javascript
JS实现时间格式化的方式汇总
2013/10/16 Javascript
JavaScript window.location对象
2014/11/14 Javascript
javascript判断并获取注册表中可信任站点的方法
2015/06/01 Javascript
js实现的星星评分功能函数
2015/12/09 Javascript
AngularJS自动表单验证
2016/02/01 Javascript
jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
2016/03/14 Javascript
基于javascript实现样式清新图片轮播特效
2016/03/30 Javascript
通过jsonp获取json数据实现AJAX跨域请求
2017/01/22 Javascript
基于js粘贴事件paste简单解析以及遇到的坑
2017/09/07 Javascript
微信小程序出现wx.navigateTo页面不跳转问题的解决方法
2017/12/26 Javascript
python 中文字符串的处理实现代码
2009/10/25 Python
在Python中处理字符串之ljust()方法的使用简介
2015/05/19 Python
Djang中静态文件配置方法
2015/07/30 Python
解决python 读取excel时 日期变成数字并加.0的问题
2019/10/08 Python
tensorflow自定义激活函数实例
2020/02/04 Python
Tensorflow--取tensorf指定列的操作方式
2020/06/30 Python
重构Python代码的六个实例
2020/11/25 Python
自考生毕业自我鉴定
2013/10/10 职场文书
酒店总经理欢迎词
2014/01/08 职场文书
全陪导游欢迎词
2014/01/17 职场文书
设计师求职信模板
2014/05/06 职场文书
诉讼财产保全担保书
2014/05/20 职场文书
幼儿园植树节活动总结
2014/07/04 职场文书
最新离婚协议书范本
2014/08/19 职场文书
安全演讲稿开场白
2014/08/25 职场文书
微笑面对生活演讲稿
2014/09/23 职场文书
导游词之凤凰古城
2019/10/22 职场文书
Python爬虫之用Xpath获取关键标签实现自动评论盖楼抽奖(二)
2021/06/07 Python