background image

php

 

递归实现无限分类 格式化数组

本文主要讲述了 php array_multisort 函数对数据库结果进行复杂排序的使用说明,供

大家参考下

首先讲一下需求:数据库中有 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 子句的功能。

第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数
组中相应值的大小来排序,依此类推。
本函数的参数结构有些不同寻常,但是非常灵活。第一个参数必须是一个数组。接下来的
每个参数可以是数组或者是下面列出的排序标志。
这样我们现在有这样一组数据
本篇主要是对使用 php

 

递归实现无限分类 格式化数组进行了详细的分析介绍,欢迎参考

我们要做一个商品的无限分类
首先数据库字段为:
id ----------商品主键 id
fid ---------- 商品父 id
name ---------- 商品名
最后输出的数组格式为

 

复制代码 代码如下:
 
<PRE 

class

=php name="code"><PRE 

class

=php name="code">

array

(

0=>

array

(

'id'=>1,