zoukankan      html  css  js  c++  java
  • 如何利用php array_multisort函数 对数据库排序

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

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

    排序顺序标志:
    SORT_ASC C 按照上升顺序排序
    SORT_DESC C 按照下降顺序排序
    排序类型标志:
    SORT_REGULAR C 将项目按照通常方法比较
    SORT_NUMERIC C 将项目按照数值比较
    SORT_STRING C 将项目按照字符串比较
    每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效 C 在此之前为默认值 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);

  • 相关阅读:
    刷题第一天各种蒙圈
    如何用MATLAB读stl并显示点云文件
    MATLA总结三
    word里如何将模板的样式(标题啊、字体啊)导入到另外的模板里
    Asp.Net跨平台:Ubuntu14.0+Mono+Jexus+Asp.Net
    Newtonsoft.Json输出Json时动态忽略属性
    Redis 系列 (一) StackExchange.Redis的使用
    jquery选择器如何获取父级元素、同级元素、子元素
    多线程的应用小结
    nginx1.18支持http2.0
  • 原文地址:https://www.cnblogs.com/2881064178dinfeng/p/6229747.html
Copyright © 2011-2022 走看看