≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 网络编程 > PHP笔记

PHP 使用二维数组实现SQL的ORDER BY排序的方法

人气:860 时间:2018-09-17

这篇文章主要为大家详细介绍了PHP 使用二维数组实现SQL的ORDER BY排序的方法,具有一定的参考价值,可以用来参考一下。

经测试代码如下:

<?php
/**
 *
 * @package BugFree
 * @version $Id: FunctionsMain.inc.php,v 1.32 2005/09/24 11:38:37 wwccss Exp $

Sort an two-dimension array by some level two items use array_multisort() function.

sysSortArray($Array,"Key1","SORT_ASC","SORT_RETULAR","Key2"……)
 * @author Chunsheng Wang <wwccss@263.net>
 * @param array $ArrayData the array to sort.
 * @param string $KeyName1 the first item to sort by.
 * @param string $SortOrder1 the order to sort by("SORT_ASC"|"SORT_DESC")
 * @param string $SortType1 the sort type("SORT_REGULAR"|"SORT_NUMERIC"|"SORT_STRING")
 * @return array sorted array.
 */
function sysSortArray($ArrayData, $KeyName1, $SortOrder1 = "SORT_ASC", $SortType1 = "SORT_REGULAR")
{
     if(!is_array($ArrayData))
        {
         return $ArrayData;
         }
  
     // Get args number.
    $ArgCount = func_num_args();
  
     // Get keys to sort by and put them to SortRule array.
    for($I = 1;$I < $ArgCount;$I ++)
    {
         $Arg = func_get_arg($I);
         if(!eregi("SORT", $Arg))
            {
             $KeyNameList[] = $Arg;
             $SortRule[] = '$' . $Arg;
             }
        else
            {
             $SortRule[] = $Arg;
             }
         }
  
     // Get the values according to the keys and put them to array.
    foreach($ArrayData AS $Key => $Info)
    {
         foreach($KeyNameList AS $KeyName)
        {
             ${$KeyName}[$Key] = $Info[$KeyName];
             }
         }
  
     // Create the eval string and eval it.
    $EvalString = 'array_multisort(' . join(",", $SortRule) . ',$ArrayData);';
     eval ($EvalString);
     return $ArrayData;
    }

// ################# 示例 #################
$arr = array(
    array(
        'name' => '学习',
         'size' => '1235',
         'type' => 'jpe',
         'time' => '1921-11-13',
         'class' => 'dd',
        ),
     array(
        'name' => '中国功夫',
         'size' => '153',
         'type' => 'jpe',
         'time' => '2005-11-13',
         'class' => 'jj',
        ),
     array(
        'name' => '编程',
         'size' => '35',
         'type' => 'gif',
         'time' => '1997-11-13',
         'class' => 'dd',
        ),
     array(
        'name' => '中国功夫',
         'size' => '65',
         'type' => 'jpe',
         'time' => '1925-02-13',
         'class' => 'yy',
        ),
     array(
        'name' => '中国功夫',
         'size' => '5',
         'type' => 'icon',
         'time' => '1967-12-13',
         'class' => 'rr',
        ),
    );

print_r($arr);

// 注意:按照数字方式排序时 153 比 65 小
$temp = sysSortArray($arr, "name", "SORT_ASC", "type", "SORT_DESC", "size", "SORT_ASC", "SORT_STRING");

print_r($temp);

?>



/***   来自四海网(www.q1010.com)   ***/

本文来自:http://www.q1010.com/173/84-0.html

注:关于PHP 使用二维数组实现SQL的ORDER BY排序的方法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:二维数组,排序

您可能感兴趣的文章

  • PHP 使用二维数组读取数据库并按指定列输出的方法
上一篇:PHP 九个实用函数的使用示例
下一篇:PHP 实现Base64中英文编码、JavaScript解码的示例
热门文章
  • PHP 写入WRITE编码为UTF8的文件示例
  • PHP 中文字符串截取函数示例:支持gb2312,gbk,big
  • PHP 简单留言板的制作示例
  • 解决Fatal error: Call to undefined function mb_convert_encoding() in错误问题
  • PHP语言基础(标记、注释、变量、数组、常量、函数)示例
  • php 生成迅雷链接的简单示例
  • php 获取短网址的实现方法
  • PHP 通用分页类的简单示例
  • PHP 使用文件方式导入导出整个MYSQL数据库的实现方法
  • php 获取MYSQL错误的简单示例
  • 最新文章
    • 解决PHP使用redis实现统计缓存MySQL压力的问题
    • php 简单的上传进度条的简单示例
    • php 给html中引用的js和css路径打上版本号的实现方法
    • php 实现计算年龄精准到年月日的实例
    • php+ajax无刷新分页的简单示例
    • 解决php+ajax无刷新上传图片的问题
    • 解决PHP生成HTML静态页面的问题
    • 解决PHP使用uniqid函数生成唯一ID的问题
    • 解决PHP防刷票的一些问题
    • 微信access_token的获取开发的实现方法

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。