如何利用php array_multisort函数 对数据库结果进行复杂排序


Posted in PHP onJune 08, 2013

首先讲一下需求:数据库中有4个字段分别是id,volume,edition,name. 要求对查询结果按照volume+edition从大到小排序。
下面将一下array_multisort函数
array_multisort() 可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。

关联(string)键名保持不变,但数字键名会被重新索引。

排序顺序标志:
SORT_ASC ? 按照上升顺序排序
SORT_DESC ? 按照下降顺序排序

排序类型标志:
SORT_REGULAR ? 将项目按照通常方法比较
SORT_NUMERIC ? 将项目按照数值比较
SORT_STRING ? 将项目按照字符串比较

每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效 ? 在此之前为默认值 SORT_ASC 和 SORT_REGULAR。

输入数组被当成一个表的列并以行来排序——这类似于 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。

本函数的参数结构有些不同寻常,但是非常灵活。第一个参数必须是一个数组。接下来的每个参数可以是数组或者是下面列出的排序标志。

这样我们现在有这样一组数据

// 这是一组从数据库查询出来的结果
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
//我们需要先做出一个volume+edition的数组来
foreach($data as $val){
     $arr[] = $val['volume'] + $val['edition']; 
}
// 将$arr根据降序排列
// 把 $data 作为最后一个参数,以通用键排序
array_multisort($arr, SORT_DESC, $data);

这样就实现了我们需要的功能
PHP 相关文章推荐
php生成WAP页面
Oct 09 PHP
PHP XML备份Mysql数据库
May 27 PHP
php中使用parse_url()对网址进行解析的实现代码(parse_url详解)
Jan 03 PHP
工厂模式在Zend Framework中应用介绍
Jul 10 PHP
php读取文件内容至字符串中,同时去除换行、空行、行首行尾空格(Zjmainstay原创)
Jul 31 PHP
php 生成短网址原理及代码
Jan 23 PHP
php使用正则表达式获取图片url的方法
Jan 16 PHP
PHP使用array_fill定义多维数组的方法
Mar 18 PHP
php查询mysql数据库并将结果保存到数组的方法
Mar 18 PHP
php通过分类列表产生分类树数组的方法
Apr 20 PHP
PHP实现获取中英文首字母
Jun 19 PHP
php实现文章评论系统
Feb 18 PHP
php引用返回与取消引用的详解
Jun 08 #PHP
PHP stripos()函数及注意事项的分析
Jun 08 #PHP
php自动加载机制的深入分析
Jun 08 #PHP
深入理解curl类,可用于模拟get,post和curl下载
Jun 08 #PHP
coreseek 搜索英文的问题详解
Jun 08 #PHP
探讨如何在php168_cms中提取验证码
Jun 08 #PHP
如何使用php绘制在图片上的正余弦曲线
Jun 08 #PHP
You might like
透析PHP的配置文件php.ini
2006/10/09 PHP
PHP中echo和print的区别
2014/08/28 PHP
微信支付的开发流程详解
2016/09/13 PHP
关于PHP定时发送服务的解决办法
2017/04/23 PHP
PHP Swoole异步Redis客户端实现方法示例
2019/10/24 PHP
jquery中的$(document).ready()与window.onload的区别
2009/11/18 Javascript
JavaScript中的排序算法代码
2011/02/22 Javascript
jquery 之 $().hover(func1, funct2)使用方法
2012/06/14 Javascript
jquery原创弹出层折叠效果点击折叠弹出一个层
2014/03/12 Javascript
JavaScript用Number方法实现string转int
2014/05/13 Javascript
14个有用的Jquery技巧分享
2015/01/08 Javascript
关于事件mouseover ,mouseout ,mouseenter,mouseleave的区别
2015/10/12 Javascript
jQuery悬停文字提示框插件jquery.tooltipster.js用法示例【附demo源码下载】
2016/07/19 Javascript
javascript实现鼠标点击页面 移动DIV
2016/12/02 Javascript
详解用vue.js和laravel实现微信支付
2017/06/23 Javascript
form表单数据封装成json格式并提交给服务器的实现方法
2017/12/14 Javascript
Vue使用高德地图搭建实时公交应用功能(地图 + 附近站点+线路详情 + 输入提示+换乘详情)
2018/05/16 Javascript
详解一个基于react+webpack的多页面应用配置
2019/01/21 Javascript
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
2019/04/08 Javascript
Python中isnumeric()方法的使用简介
2015/05/19 Python
python好玩的项目—色情图片识别代码分享
2017/11/07 Python
解决在Python编辑器pycharm中程序run正常debug错误的问题
2019/01/17 Python
python识别图像并提取文字的实现方法
2019/06/28 Python
使用 Django Highcharts 实现数据可视化过程解析
2019/07/31 Python
wxPython:python首选的GUI库实例分享
2019/10/05 Python
用openCV和Python 实现图片对比,并标识出不同点的方式
2019/12/19 Python
PyQt5 文本输入框自动补全QLineEdit的实现示例
2020/05/13 Python
html5+svg学习指南之SVG基础知识
2014/12/17 HTML / CSS
鱼油专家:Omegavia
2016/10/10 全球购物
荷兰在线钓鱼商店:Raven
2019/06/26 全球购物
Servlet如何得到客户端机器的信息
2014/10/17 面试题
爱岗敬业演讲稿范文
2014/01/14 职场文书
五分钟演讲稿
2014/04/30 职场文书
大三学年自我鉴定范文(3篇)
2014/09/28 职场文书
单位工作证明格式模板
2014/10/04 职场文书
2015年村计划生育工作总结
2015/04/28 职场文书