• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-26) 23次浏览 已收录 0个评论

首先讲一下需求:数据库中有4个字段分别是id,volume,edition,name. 要求对查询结果按照volume+edition从大到小排序。
下面将一下array_multisort函数
array_multisort() 可以用来一次对多个数组进行排序,(、本文来源gao@!dai!ma.com搞$$代^@码网*搞gaodaima代码或者根据某一维或多维对多维数组进行排序。

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

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

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

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

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

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

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

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


这样就实现了我们需要的功能


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:如何利用php array_multisort函数 对数据库结果进行复杂排序_php技巧
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址