php 递归 实现无限分类 格式化数组
2012-05-27 13:47
806 查看
我们要做一个商品的无限分类
首先数据库字段为:
id ----------商品主键id
fid
---------- 商品父id
name
---------- 商品名
最后输出的数组格式为
php代码:
函数首先查询出所有fid为0的类
通过while逐个循环进行回调查找fid为当前类的id的子类
首先数据库字段为:
id ----------商品主键id
fid
---------- 商品父id
name
---------- 商品名
最后输出的数组格式为
array( 0=>array( 'id'=>1, 'fid'=>0, 'name'=>'法国货' 'child'=>array( 0=>array( 'id'=>12, 'fid'=>1, 'name'=>'香水' 'child'=>array( 0=>array( 'id'=>34, 'fid'=>12, 'name'=>'女用香水' ) ) ), 1=>array( 'id'=>13, 'fid'=>1, 'name'=>'笔记本' 'child'=>NUll ) ) ), 1=>array(), //格式同上我就不再重复写了 没什么意义 2=>array() )
php代码:
<?php //数据库我用的mysql PDO 但是整个思路又是一样的 $conn=mysql_connect('localhost','root','123'); if(mysql_errno()){ printf('连接失败'.mysql_error()); } mysql_select_db('edeng'); mysql_set_charset('utf8'); /* *递归函数 *@param id 要查询fid=$id的所有子类 这里将$id的默认值为设为0 是因为我在数据库中将最顶层的类别的fid设置为0 */ function get_array($id=0){ $sql="select id,fid,cname from e_cat where fid= $id"; $result=mysql_query($sql); $arr=array(); if($result && mysql_affected_rows()){ while($rows=mysql_fetch_assoc($result)){ $rows['child']=get_array($rows['id']); $arr[] = $rows; } return $arr; } } echo '<pre>'; $result = get_array(); print_r($result);
函数首先查询出所有fid为0的类
通过while逐个循环进行回调查找fid为当前类的id的子类
相关文章推荐
- php 递归 实现无限分类 格式化数组
- 利用php递归实现无限分类 格式化数组的详解
- PHP递归实现无限分类数组处理
- PHP-mySql实现无限分类(递归、数组)
- PHP递归遍历多维数组实现无限分类的方法
- PHP递归遍历多维数组实现无限分类的方法
- PHP不用递归实现无限分类数据的树形格式化 5行9行代码修改
- php不用递归实现无限分类数据的树形格式化
- PHP递归实现无限级分类
- php实现无限级分类查询(递归、非递归)
- php实现无限级分类查询(递归、非递归)
- php实现无限级分类(递归方法)
- php递归实现无限分类生成下拉列表
- PHP无限分类代码,支持数组格式化、直接输出菜单两种方式
- php+mysql不用递归实现的无限级分类实例(非递归)
- PHP迭代与递归实现无限级分类
- 9行代码,不用递归实现无限分类数据的树形格式化
- php实现无限级分类查询(递归、非递归)
- php下利用递归实现无限级分类